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

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

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

解决方案:通过 history.pushState 添加历史记录名目,history.onpopstate 监听历史记录条目发生变化时,调用小程序 API wx.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 会存值,如果直接关闭页面,不会被清除,那么在小程序中访问时就直接回退了。

原文:https://developers.weixin.qq.com/community/develop/article/doc/0000a675850f08937e09e44385b413

发表评论
* 昵称
* Email
* 网址
* 评论