首页 > 其他分享 >MUI关闭指定页面之外的其余页面

MUI关闭指定页面之外的其余页面

时间:2022-12-04 15:11:13浏览次数:40  
标签:wvs plus 关闭 var webview MUI id 页面

有兴趣可以关注公众号: 图计算与算法

问题:
最近在写一个类似微信的APP,基于mui来在android端以及ios端呈现,但是有个问题是在退出登录切换账号的时候发现app会加载之前的缓存的webview页面,这就需要我们在退出的时候打开登录页,关闭除登录页外的其他所有页面。

解决方法:
一般我们创建打开一个webview需要提供两个参数,pageurl 和 pageid, 那么我们就可以获取所有的webview,然后根据页面Url或者页面id来判断哪个我们需要保留,其余的全部close,这样我们就可以保留跳转到比如登录页面,其余页面全部close。
(1) 根据页面ID来进行比较关闭
// 退出


				var logout = document.getElementById("logout");

				logout.addEventListener("tap", function() {

					//所有窗口对象 
					var wvs = plus.webview.all();
					//首页窗口对象 
					var launch = plus.webview.getLaunchWebview();
					//当前窗口对象
					var self = plus.webview.currentWebview();
					// 首页以及当前窗口对象,不关闭; 
					for (var i = 0, len = wvs.length; i < len; i++) {
						//选定某一页不关wvs[i].id === localStorage.homeWebId 
						if (wvs[i].id === launch.id ||
							wvs[i].id === self.id ||
							wvs[i].id === localStorage.homeWebId) {
							continue;
						} else {
							//关闭中间的窗口对象,为防止闪屏,不使用动画效果; 
							wvs[i].close('none');
						}
					}
					mui.openWindow('login.html', 'login.html');
				})

(2)根据页面URL来进行关闭


var curr = plus.webview.currentWebview();
var wvs = plus.webview.all();
for (var i = 0,
len = wvs.length; i < len; i++) {
  //关闭除当前页面外的其他页面
  if (wvs[i].getURL() != curr.getURL()){
    plus.webview.close(wvs[i]);
  }
  //关闭除指定页面外的其他页面
  //key 可以是指定页面名称或者其他关键字
  if (wvs[i].getURL().indexOf("Key") == -1){
    plus.webview.close(wvs[i]);
  }
}
//打开login页面后再关闭setting页面
plus.webview.open('../login/login.html');
curr.close();

标签:wvs,plus,关闭,var,webview,MUI,id,页面
From: https://www.cnblogs.com/kason-seu/p/16949922.html

相关文章