js关闭当前页面

高程三截图

window.cloce()方法看似可以关闭打开的窗口,可是《高程三》已经明确指出这个方法仅适用于通过window.open()打开的窗口

网上摘抄来这么一段代码,通过userAgent检测浏览器类型,然而这三种情况都是打开了空页面😣

 

var userAgent = navigator.userAgent;
if (userAgent.indexOf("Firefox") != -1 || userAgent.indexOf("Chrome") !=-1) {
    window.location.href="about:blank";   
}else if(userAgent.indexOf('Android') > -1 || userAgent.indexOf('Linux') > -1){
    window.opener=null;window.open('about:blank','_self','').close(); 
}else {
    window.pener = null;
    window.open("about:blank", "_self");
    window.close();
}

由于我最近在做支付,所以涉及到的就是微信、支付宝、百度钱包、京东、QQ等,在内置浏览器中支付完成或者提示用户错误信息之后关闭页面,由于在微信支付宝百度钱包中,他们对页面关闭进行了封装,传统的window.close()是无效的,必须要使用它们的js代码才能关闭。

所以下面是三种关闭的方法(其他的暂时还没有找到):

 

WeixinJSBridge.call('closeWindow');//微信 
AlipayJSBridge.call('closeWebview'); //支付宝 关闭窗口(别名)
AlipayJSBridge.call('exitApp'); // 支付宝 (退出当前H5应用)
AlipayJSBridge.call('popWindow',{  // 关闭窗口,可传递参数
    data: {
    }
});
BLightApp.closeWindow();//百度钱包

阿里的文档
阿里文档2
有时支付宝的关闭在安卓上面不是很好用,原因是当页面加载完后会创建 AlipayJSBridge对象,同时会触发AlipayJSBridgeReady事件,当执行AlipayJSBridge.call('closeWebview')操作时,AlipayJSBridge还没有创建,所以无法执行。因此我们需要对AlipayJSBridgeReady事件进行监听。

 

document.addEventListener('AlipayJSBridgeReady',function(){
      AlipayJSBridge.call('closeWebview');
 })

通过浏览器的头判断是那种浏览器:

 

var ua = navigator.userAgent.toLowerCase(); 
if(ua.match(/MicroMessenger/i)=="micromessenger") { 
  alert("微信客户端"); 
} else if(ua.indexOf("alipay")!=-1){ 
  alert("支付宝客户端"); 
}else if(ua.indexOf("baidu")!=-1){ 
  alert("百度客户端"); 
}

保存历史记录:

 

window.addEventListener("popstate", function(e) {
    var state = {
        title: "title",
        url: "#"
    };
    window.history.pushState(state, "title", "#");
}, false);

popstate 点击后退按钮触发
history.pushState接收三个参数:状态对象、新状态的标题、可选的相对URL;


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值