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


Posted in Javascript onApril 15, 2019

实际上关键词叫 微信pushState只能分享落地页 更贴切一点

应用场景:

  1. vue + vue-router
  2. vue-router使用hash模式(history模式没试过)
  3. 不使用微信的js-sdk(因为我这个项目是可配置域名的商城,比较特殊,不能使用微信sdk)

这个方案并不是最优秀的,会对性能造成一定的影响

HTML5 history.pushState

vue-router的内部是通过 history.pushState 和 history.replaceState 实现的。但是iOS设备的微信浏览器不会去检测它们的变化。但是我们可以通过更新 location.href 让微信浏览器识别到当前的url。

// vue-router/src/util/push-state.js

export function pushState (url?: string, replace?: boolean) {
 saveScrollPosition()
 // try...catch the pushState call to get around Safari
 // DOM Exception 18 where it limits to 100 pushState calls
 const history = 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)
 }
}

export function replaceState (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) {
   // 微信浏览器判断
   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 随意。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript json 新手入门文档
Dec 03 Javascript
JavaScript执行顺序详细介绍
Dec 04 Javascript
jQuery实现多按钮单击变色
Nov 27 Javascript
JavaScript电子时钟倒计时
Jan 09 Javascript
js验证手机号、密码、短信验证码代码工具类
Jun 24 Javascript
ionic 3.0+ 项目搭建运行环境的教程
Aug 09 Javascript
vue移动端路由切换实例分析
May 14 Javascript
一个Vue视频媒体多段裁剪组件的实现示例
Aug 09 Javascript
基于Vue-Cli 打包自动生成/抽离相关配置文件的实现方法
Dec 09 Javascript
Jquery Datatables的使用详解
Jan 30 jQuery
react中hook介绍以及使用教程
Dec 11 Javascript
原生js实现九宫格拖拽换位
Jan 26 Javascript
vue--vuex详解
Apr 15 #Javascript
详解如何模拟实现node中的Events模块(通俗易懂版)
Apr 15 #Javascript
小程序数据通信方法大全(推荐)
Apr 15 #Javascript
前端面试知识点目录一览
Apr 15 #Javascript
详解vuex持久化插件解决浏览器刷新数据消失问题
Apr 15 #Javascript
vue-cli项目使用mock数据的方法(借助express)
Apr 15 #Javascript
说说Vuex的getters属性的具体用法
Apr 15 #Javascript
You might like
目录,文件操作详谈―PHP
2006/11/25 PHP
PHP mysql与mysqli事务使用说明 分享
2013/08/17 PHP
php连接oracle数据库的方法(测试成功)
2016/05/26 PHP
PHP屏蔽关键字实现方法
2016/11/17 PHP
PHP数组相加操作及与array_merge的区别浅析
2016/11/26 PHP
延时重复执行函数 lLoopRun.js
2007/05/08 Javascript
JavaScript 语言的递归编程
2010/05/18 Javascript
使用基于jquery的gamequery插件做JS乒乓球游戏
2011/07/31 Javascript
使用jQuery+HttpHandler+xml模拟一个三级联动的例子
2011/08/09 Javascript
根据IP的地址,区分不同的地区,查看不同的网站页面的js代码
2013/02/26 Javascript
jquery 触发a链接点击事件解决方案
2013/05/02 Javascript
JavaScript在网页中画圆的函数arc使用方法
2015/11/13 Javascript
JavaScript数组操作函数汇总
2016/08/05 Javascript
node网页分段渲染详解
2016/09/05 Javascript
Javascript中的神器——Promise
2017/02/08 Javascript
微信小程序动态的加载数据实例代码
2017/04/14 Javascript
详解KOA2如何手写中间件(装饰器模式)
2018/10/11 Javascript
使用vue开发移动端管理后台的注意事项
2019/03/07 Javascript
使用webpack搭建vue项目及注意事项
2019/06/10 Javascript
javascript操作元素的常见方法小结
2019/11/13 Javascript
Python3指定路径寻找符合匹配模式文件
2015/05/22 Python
Python字符串、元组、列表、字典互相转换的方法
2016/01/23 Python
名片管理系统python版
2018/01/11 Python
python 图像平移和旋转的实例
2019/01/10 Python
基于Python打造账号共享浏览器功能
2019/05/30 Python
在PyTorch中Tensor的查找和筛选例子
2019/08/18 Python
python模块导入的方法
2019/10/24 Python
解决windows下python3使用multiprocessing.Pool出现的问题
2020/04/08 Python
使用Python操作MySQL的小技巧
2020/09/10 Python
对pytorch中x = x.view(x.size(0), -1) 的理解说明
2021/03/03 Python
匡威俄罗斯官网:Converse俄罗斯
2020/05/09 全球购物
服装公司总经理岗位职责
2013/11/30 职场文书
禁止酒驾标语
2014/06/25 职场文书
运动会演讲稿50字
2014/08/25 职场文书
幼儿教师辞职信范文
2015/03/02 职场文书
Mysql MVCC机制原理详解
2021/04/20 MySQL