vue单页面在微信下只能分享落地页的解决方案

应用场景:

  1. vue + vue-router
  2. vue-router使用hash模式(history模式没试过)
  3. 不使用微信的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:8080http://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随意。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值