详解解决小程序中webview页面多层history返回问题
2019-08-20 09:58
3831 查看
小程序开发中遇到的问题:小程序中嵌套了一个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会存值,如果直接关闭页面,不会被清除,那么在小程序中访问时就直接回退了。
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- 小程序中跳到webview页面没有返回按钮?已解决
- 2017-6-14 关于使用history.go的问题!配合原生应用嵌入H5页面(只有一个webview的的单页应用)返回历史列表记录的问题
- android Webview中注入js,用于解决第三方页中出现返回事件window.history.go(-1),无法响应问题
- 关于webview加载网页,返回后总是刷新页面问题解决
- 使用列表组织WebView解决返回页面总是刷新的问题
- 详解如何探测小程序返回到webview页面
- Web程序中利用web.config解决无法输出excel页面的问题
- 在Fragment中重写返回键以及WebView加载重定向页面返回问题
- 解决 hybird 应用中重复获取 WebView,导致页面元素无法识别的问题
- 解决 hybird 应用中重复获取 WebView,导致页面元素无法识别的问题
- 解决 hybird 应用中重复获取 WebView,导致页面元素无法识别的问题
- 完美解决客户端webview持有的页面缓存,不会立即释放的问题
- 关于Webview执行goBack不能返回的问题解决
- 解决 hybird 应用中重复获取 WebView,导致页面元素无法识别的问题
- android webview: 视频全屏播放按返回页面被放大的问题
- 关于WebView.goBack()在有的网页无法返回的问题的解决方法
- 【微信小程序】解决 竖向<scroll-view>组件 “竖向滚动页面出现遮挡”问题
- Web程序中利用web.config解决无法输出excel页面的问题
- Android 解决系统字体变大导致WebView页面显示错乱问题
- android webview 如何去广告和如何解决重定向返回的问题。