zoukankan      html  css  js  c++  java
  • 如何绕过chrome的弹窗拦截机制

    https://www.cnblogs.com/foru/p/3924385.html?utm_source=tuicool

     

     

    在chrome的安全机制里面,非用户触发的window.open方法,是会被拦截的。举个例子: 

    var btn = $('#btn');
    
          btn.click(function () {
    
    
           //不会被拦截
    
             window.open('http://cssha.com')
    
    
     });

    上面的代码中,window.open是用户触发的时候,是不会被拦截的,可以正常打开新窗口。再看下面这个:

     var btn = $('#btn');
    btn.click(function () {
    
    $.ajax({
    url: 'wwwox',
    
    success: function (url) {
    
    //会被拦截
    
    window.open(url);
    
    }
    
    })
    
    });

    上面的代码中,用户没有直接出发window.open,而是发出一个ajax请求,window.open方法被放在了ajax的回调函数里,这样的情况是会被拦截的。

    那么,当用户点击按钮,发出ajax请求,如何在ajax请求完成后再打开新窗口,又不被拦截呢? 接着往下看:

     var btn = $('#btn');
    btn.click(function () {
    
    //打开一个不被拦截的新窗口
    
    var newWindow = window.open();
    
    $.ajax({
    
    url: 'wwwox',
    
    success: function (url) {
    
    //修改新窗口的url
    
    newWindow.location.href = url;
    
    }
    
    })
    
    });
    

      

    上面的代码中,用户安点击按钮的时候,先打开一个空白页,再发ajax请求,在ajax回调里面修改新窗口的.location.href,这样就不会被拦截啦

  • 相关阅读:
    Git
    linux下利用virtualenv搭建虚拟环境
    Session和Cookie
    Redis
    从零开始学Go之基本(二):包、函数声明与格式化输出
    从零开始学Go之HelloWorld
    C++ vector容器使用
    FIRST集和FOLLOW集的计算
    go编译错误:runnerw.exe:CreateProcess failed with error 216:
    Linux下vi编辑器常用命令
  • 原文地址:https://www.cnblogs.com/jarekpierre/p/9336042.html
Copyright © 2011-2022 走看看