解决小程序中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' +
        '#wec

你可能感兴趣的:(文章,webview,小程序)