小程序开发中遇到的问题:小程序中嵌套了一个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是我们前端开发从PC端演进到移动端的一个重要载体,现在大家每天使用的App,webview都发挥着它的重要性。接下来让我们从webview看世界。提到应用场景,大家最直观的能想到一些App内嵌的页面,为我们提供各种各样的交互
通常我们在自己开发的 APP 中打开网页无非两种方法: 一是跳转到系统自带的浏览器,二是使用 WebView 控件加载页面。使用 WebView 控件的好处就是可以通过各种 api 接口来定制各种行为
不聚焦问题;如果引入了fastclick,那么需要修改源码,如下;如果还有问题,尝试监听input的focus,然后延时聚焦;如果没有引入fastclick,网上找其他原因吧,还没遇到过
使用过人气很高的flutter_webview_plugin,但是缺少2个重要的功能。也在打开多个WebView时会出错。不能在JS中调用Flutter方法;不能在H5进入某个URL之前拦截
现在的App开发,或多或少都会用到Hybrid模式,到了WebView这边,经常会加载一些js文件(例如和WebView用来Native通信的bridge.js),而这些js文件不会经常发生变化,所以我们希望js在WebView里面加载一次之后
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!