小程序webview 缓存_详解解决小程序中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会存值,如果直接关闭页面,不会被清除,那么在小程序中访问时就直接回退了。

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

小程序webview页面多层history返回需要通过一些技巧来实现。 首先,我们需要在打开webview页面时,记录下当前页面的url。可以通过监听页面生命周期的方式,当页面加载完成后,获取当前页面的url,并将其存储到某个变量。 接下来,在webview页面返回按钮点击事件,我们可以在每次返回时,通过判断历史记录的长度来决定是返回上一级还是关闭webview页面。 具体的实现逻辑如下: 1. 在小程序打开webview页面时,使用wx.navigateTo或wx.redirectTo等方法,并在目标页面的onLoad生命周期获取当前页面的url,并将其存储到某个全局变量。 2. 在webview页面,可以通过原生的JavaScript的history对象来控制历史记录的返回。例如,使用history.go(-1)来返回上一级页面。 3. 在webview页面返回按钮的点击事件,我们可以通过去全局变量获取前面存储的当前页面的url,以及通过JavaScript脚本来获取当前页面的url,进行比较。如果二者一致,说明当前页面webview页面打开的第一个页面,此时直接关闭webview页面即可;如果不一致,则使用history.go(-1)来返回上一级页面。 需要注意的是,如果webview页面存在多个层级的历史记录,我们可以通过多次调用history.go(-1)来依次返回上一级页面,直到返回到目标页面为止。 总结而言,小程序实现webview页面多层历史记录的返回,需要在打开webview页面时记录当前页面的url,并在返回时通过比较当前页面的url来判断是否需要返回上一级页面或者关闭webview页面。通过此方法可以实现多层历史记录的返回功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值