详解解决小程序中webview页面多层history返回问题


Posted in Javascript onAugust 20, 2019

小程序开发中遇到的问题:小程序中嵌套了一个webview页面,webview页面中有静默授权(A1页面静默授权后重定向到A2页面),点小程序原生的返回按钮会返回到A1页面,然后页面就会反复静默授权

预期表现:点小程序原生的返回按钮后返回到小程序上个页面

解决方案:通过history.pushState添加历史记录名目,history.onpopstate监听历史记录条目发生变化时,调用小程序APIwx.navigateBack

window.addEventListener('popstate', (event) => {
  wx.miniProgram.navigateBack();
});
const code = getSearch('code'); // 伪代码,获取查询参数
if (!code) { // 页面A1
  if (isWeixin()) {
    // 微信环境
    const redirectUrl = window.location.href + '&code=1';
    window.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize' + '?appid=' + appId +
    '&redirect_uri=' + encodeURIComponent(redirectUrl) +
    '&response_type=code&scope=snsapi_userinfo' +
    '#wechat_redirect'; // 静默授权伪代码
  } else {
    alert('当前不是微信环境');
  }
} else { // 页面A2
  history.pushState({page: 1}, null, window.location.href);
}

刚开始想的解决办法是用localStorage,跳转到A2时存储一个值,返回到A1时获取这个值,如果有值就清除这个值并且回退到小程序页面。听起来似乎也可行,但小程序的缓存和微信的缓存是同步的,如果在微信环境中直接访问A1页面,重定向到A2会存值,如果直接关闭页面,不会被清除,那么在小程序中访问时就直接回退了。

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

Javascript 相关文章推荐
JS验证日期的格式YYYY-mm-dd 具体实现
Jun 29 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
Sep 30 Javascript
JavaScript中的值类型转换介绍
Dec 31 Javascript
JavaScript中数据结构与算法(三):链表
Jun 19 Javascript
微信小程序 textarea 详解及简单使用方法
Dec 05 Javascript
web前端vue之CSS过渡效果示例
Jan 10 Javascript
vuex的简单使用教程
Feb 02 Javascript
在 vue-cli v3.0 中使用 SCSS/SASS的方法
Jun 14 Javascript
vue树形结构获取键值的方法示例
Jun 21 Javascript
使用Vue做一个简单的todo应用的三种方式的示例代码
Oct 20 Javascript
详解vue-cli中使用rem,vue自适应
May 06 Javascript
VueJS 取得 URL 参数值的方法
Jul 19 Javascript
JavaScript使用表单元素验证表单的示例代码
Aug 20 #Javascript
vue悬浮可拖拽悬浮按钮的实例代码
Aug 20 #Javascript
JS中的算法与数据结构之链表(Linked-list)实例详解
Aug 20 #Javascript
使用 webpack 插件自动生成 vue 路由文件的方法
Aug 20 #Javascript
微信小程序webview与h5通过postMessage实现实时通讯的实现
Aug 20 #Javascript
JS中的算法与数据结构之队列(Queue)实例详解
Aug 20 #Javascript
JS中的算法与数据结构之栈(Stack)实例详解
Aug 20 #Javascript
You might like
session 的生命周期是多长
2006/10/09 PHP
不错的PHP学习之php4与php5之间会穿梭一点点感悟
2007/05/03 PHP
PHP include任意文件或URL介绍
2014/04/29 PHP
Gird事件机制初级读本
2007/03/10 Javascript
项目实践之javascript技巧
2007/12/06 Javascript
javascript 写类方式之五
2009/07/05 Javascript
Aptana调试javascript图解教程
2009/11/30 Javascript
打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
2014/10/11 Javascript
JavaScript中的Object对象学习教程
2016/05/20 Javascript
jQuery弹出层后禁用底部滚动条(移动端关闭回到原位置)
2016/08/29 Javascript
Easyui笔记2:实现datagrid多行删除的示例代码
2017/01/14 Javascript
Node.JS文件系统解析实例详解
2017/05/15 Javascript
JavaScript实现鼠标滚轮控制页面图片切换功能示例
2017/10/14 Javascript
Angular中支持SCSS的方法
2017/11/18 Javascript
JavaScript调用模式与this关键字绑定的关系
2018/04/21 Javascript
原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
2018/05/03 Javascript
nuxt配置通过指定IP和端口访问的实现
2020/01/08 Javascript
Map与WeakMap类型在JavaScript中的使用详解
2020/11/18 Javascript
[01:04:30]Fnatic vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
python redis连接 有序集合去重的代码
2019/08/04 Python
python几种常用功能实现代码实例
2019/12/25 Python
Python列表如何更新值
2020/05/27 Python
Keras在训练期间可视化训练误差和测试误差实例
2020/06/16 Python
Python使用文件操作实现一个XX信息管理系统的示例
2020/07/02 Python
ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
2020/10/21 Python
美国体育用品在线:Modell’s Sporting Goods
2018/06/07 全球购物
仪器仪表检测毕业生自荐信
2013/10/31 职场文书
证婚人经典证婚词
2014/01/09 职场文书
高中生学期学习自我评价
2014/02/24 职场文书
2014年小学教研工作总结
2014/12/06 职场文书
博士导师推荐信
2015/03/25 职场文书
2015年护士工作总结范文
2015/03/31 职场文书
房地产公司财务总监岗位职责
2015/04/03 职场文书
毛主席纪念堂观后感
2015/06/17 职场文书
vue实力踩坑之push当前页无效
2022/04/10 Vue.js
mysql数据库实现设置字段长度
2022/06/10 MySQL