vue单页面在微信下只能分享落地页的解决方案
应用场景:
- vue + vue-router
- vue-router使用hash模式(history模式没试过)
- 不使用微信的js-sdk(因为我这个项目是可配置域名的商城,比较特殊,不能使用微信sdk)
这个方案并不是最优秀的,会对性能造成一定的影响
解决方法
window.location.href = window.location.href
,这段代码可以让微信记录当前的url,且不会刷新页面。可以在app.vue中watch $route
在每次页面更新的时候执行一次。
// app.vue watch: { $route: { immediate: true, deep: true, handler(to) { // 微信浏览器判断 const WECHAT_BROWSER = navigator.userAgent.toLowerCase().includes('micromessenger') // 解决iOS微信浏览器分享地址只能是落地页的问题,这个操作是不会刷新页面的,query参数改变也会执行 if (WECHAT_BROWSER) { // eslint-disable-next-line window.location.href = window.location.href } } },
使用了上述方法可以解决这个问题,但是这会引出一个很奇葩的问题,在真机上进入http://192.168.1.5:8080
和http://192.168.1.5:8080/#/
这两个页面,其中有一个链接的bug依然存在。原因具体不清楚,经过测试可以在入口文件(main.js)中在页面还没有展示内容前刷新一次页面,即可解决这个问题。
// main.js // 微信浏览器判断 const WECHAT_BROWSER = navigator.userAgent.toLowerCase().includes('micromessenger') // 在url插入的search参数,可以随意,但是必须要 // 例:http://192.168.1.5:8080/?_wx_=1#/ const wxQuery = '_wx_=1' const isRepeatQuery = location.search.includes(wxQuery) if (WECHAT_BROWSER && !isRepeatQuery) { const unit = (location.search && location.search !== '?') ? '&' : '?' location.search += unit + wxQuery // 添加_wx_参数,该操作会刷新页面 }
上面的代码之所以要在hash
前面加一个?_wx_=1
参数,为了方便刷新页面给一个标志位判断是否已刷新。参数的key-value
随意。
相关推荐
yuzhu 2020-11-16
85477104 2020-11-17
KANSYOUKYOU 2020-11-16
sjcheck 2020-11-03
怪我瞎 2020-10-28
源码zanqunet 2020-10-28
gloria0 2020-10-26
王军强 2020-10-21
学习web前端 2020-09-28
QiaoranC 2020-09-25
anchongnanzi 2020-09-21
安卓猴 2020-09-12
Macuroon 2020-09-11
kiven 2020-09-11
LittleCoder 2020-09-11
Cheetahcubs 2020-09-13
小焊猪web前端 2020-09-10
颤抖吧腿子 2020-09-04
softwear 2020-08-21