浏览器打开新窗口被拦截问题

1. window.open() 方法和 form表单的submit方法

需要用户点击事件触发,将其直接写在点击事件内部,未被拦截

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
    </style>
</head>
<body>
    <button id="btn">点击</button>
    <script type="text/javascript">
        var btn = document.getElementById('btn')
        btn.onclick = function() {
            setTimeout(function(){
                window.open('http://www.baidu.com')
            },1000)
        }
    </script>
</body>
</html>

如果在js中的ajax请求的success方法内部使用这两种方法均会被拦截,将ajax请求设置为同步,即可打开窗口不被拦截


        let requestUrl = commonRequestUrl;
        let msg ='';
        $.ajax({
          async: false,
          type: "GET",
          url: requestUrl,
          dataType: "json",
          success: function(data) {
            let code = data.code;
            let msg = data.msg;
            let content = data.content;
            msg = content.msg
            window.open(`http://127.0.0.1/assets/index.html?msg=${msg}`);
          }
        });

2. a链接打开新标签页的click方法

(1)如果需要在点击事件的时候进行一些操作,且不需要考虑发送请求的情景,可在a链接的click方法内进行操作

<a href='http//:www.baidu.com' onclick='goBaidu' target='_bank'>

// 该方法在原页面执行,与新开页面无关
goBaidu() {
    localstorage.setItem('name': 'zs')
}

(2)如果需要等待ajax请求或者代码执行结果 ,在a的click方法内部直接使用window.open()或者表单的submit即可(不要写在ajax方法内部)

代码同上第二个代码段

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值