脚本宝典收集整理的这篇文章主要介绍了vue单页面在微信下只能分享落地页的解决方案,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
应用场景:
这个方案并不是最优秀的,会对性能造成一定的影响
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
随意。
以上是脚本宝典为你收集整理的vue单页面在微信下只能分享落地页的解决方案全部内容,希望文章能够帮你解决vue单页面在微信下只能分享落地页的解决方案所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。