vue单页面在微信下只能分享落地页的解决方案
实际上关键词叫微信pushState只能分享落地页更贴切一点
应用场景:
- vue+vue-router
- vue-router使用hash模式(history模式没试过)
- 不使用微信的js-sdk(因为我这个项目是可配置域名的商城,比较特殊,不能使用微信sdk)
这个方案并不是最优秀的,会对性能造成一定的影响
HTML5history.pushState
vue-router的内部是通过history.pushState和history.replaceState实现的。但是iOS设备的微信浏览器不会去检测它们的变化。但是我们可以通过更新location.href让微信浏览器识别到当前的url。
//vue-router/src/util/push-state.js exportfunctionpushState(url?:string,replace?:boolean){ saveScrollPosition() //try...catchthepushStatecalltogetaroundSafari //DOMException18whereitlimitsto100pushStatecalls consthistory=window.history try{ if(replace){ history.replaceState({key:_key},'',url) }else{ _key=genKey() history.pushState({key:_key},'',url) } }catch(e){ window.location[replace?'replace':'assign'](url) } } exportfunctionreplaceState(url?:string){ pushState(url,true) }
解决方法
window.location.href=window.location.href,这段代码可以让微信记录当前的url,且不会刷新页面。可以在app.vue中watch$route在每次页面更新的时候执行一次。
//app.vue watch:{ $route:{ immediate:true, deep:true, handler(to){ //微信浏览器判断 constWECHAT_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 //微信浏览器判断 constWECHAT_BROWSER=navigator.userAgent.toLowerCase().includes('micromessenger') //在url插入的search参数,可以随意,但是必须要 //例:http://192.168.1.5:8080/?_wx_=1#/ constwxQuery='_wx_=1' constisRepeatQuery=location.search.includes(wxQuery) if(WECHAT_BROWSER&&!isRepeatQuery){ constunit=(location.search&&location.search!=='?')?'&':'?' location.search+=unit+wxQuery//添加_wx_参数,该操作会刷新页面 }
上面的代码之所以要在hash前面加一个?_wx_=1参数,为了方便刷新页面给一个标志位判断是否已刷新。参数的key-value随意。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。