没有合适的资源?快使用搜索试试~ 我知道了~
详解解决小程序中webview页面多层history返回问题
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
5星 · 超过95%的资源 8 下载量 79 浏览量
2020-10-16
13:20:42
上传
评论
收藏 43KB PDF 举报
温馨提示
试读
1页
主要介绍了详解解决小程序中webview页面多层history返回问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
资源推荐
资源详情
资源评论
详解解决小程序中详解解决小程序中webview页面多层页面多层history返回问题返回问题
主要介绍了详解解决小程序中webview页面多层history返回问题,文中通过示例代码介绍的非常详细,对大家的
学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
小程序开发中遇到的问题:小程序中嵌套了一个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会存值,如果直接关闭页面,不会被清除,那么在小程序中访问时就直接回退了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
资源评论
- y_y_zzq2023-05-13果断支持这个资源,资源解决了当前遇到的问题,给了新的灵感,感谢分享~
weixin_38707192
- 粉丝: 3
- 资源: 921
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功