zoukankan      html  css  js  c++  java
  • js实现window.open不被拦截的解决方法汇总

    一、问题:

    今天在处理页面ajax请求过程中,想实现请求后打开新页面,就想到通过 js window.open 来实现,但是最终都被浏览器拦截了。

    二、分析:

    在谷歌搜索有没有解决方法,有些说可以通过新建a标签,模拟点击来实现,但是测试发现都实现不了,照样被浏览器拦截。
    最后找到了一个折中的办法,可以实现新页面打开,但是没有a标签的那种直接流量新页面的效果。

    三、实现代码:

    复制代码代码如下:
    $obj.click(function(){
     var newTab=window.open('about:blank');
     $.ajax({
      success:function(data){
       if(data){
        //window.open('http://www.jb51.net');
        newTab.location.href="http://www.jb51.net";
       }
      }
     })
    })


    其它方法:

    复制代码代码如下:
    <script type="text/javascript">
    <!-- 
    $( 
    function()
    {
    //方法一
    window.showModalDialog("http://www.jb51.net/");
    window.showModalDialog("http://www.jb51.net/");
     

    //方法二
    var aa=window.open();
    setTimeout(function(){
    aa.location="http://www.jb51.net";
    }, 100);
     

    var b=window.open();
    setTimeout(function(){
    b.location="http://www.jb51.net";
    }, 200);
     

    var c=window.open();
    setTimeout(function(){
    c.location="http://www.jb51.net";
    }, 300);
     

    var d=window.open();
    setTimeout(function(){
    d.location="http://www.jb51.net";
    }, 400);
     

    var ee=window.open();
    setTimeout(function(){
    ee.location="http://www.jb51.net";
    }, 500);
     

    var f=window.open();
    setTimeout(function(){
    f.location="http://www.jb51.net";
    }, 600);
     

    var g=window.open();
    setTimeout(function(){
    g.location="http://www.jb51.net";
    }, 700);
     

    var h=window.open();
    setTimeout(function(){
    h.location="http://www.jb51.net";
    }, 800);
     

    var i=window.open();
    setTimeout(function(){
    i.location="http://www.jb51.net";
    }, 900);
     

    var j=window.open();
    setTimeout(function(){
    j.location="http://www.jb51.net";
    }, 1000);
     

    //方法三
    var a = $("<a href='http://www.jb51.net' target='_blank'>Apple</a>").get(0);
    var e = document.createEvent('MouseEvents');
    e.initEvent( 'click', true, true );
    a.dispatchEvent(e);
     

    var a = $("<a href='http://www.jb51.net' target='_blank'>Apple</a>").get(0);
    var e = document.createEvent('MouseEvents');
    e.initEvent( 'click', true, true );
    a.dispatchEvent(e);
    }
     
    );
    //-->
    </script>

  • 相关阅读:
    【2020省选Day1T1】LOJ3299 「联合省选 2020 A | B」冰火战士
    题解 CF1369 D,E,F Codeforces Round #652 (Div. 2)
    题解 LOJ3298 「BJOI2020」封印(SAM,数据结构)
    题解 nflsoj99 牛顿的烈焰激光剑(容斥,DP,数学)
    判断长度为3的等差数列(经典问题)
    树形图求和:一道经典矩阵知识题
    题解 LOJ2390 「JOISC 2017 Day 1」开荒者
    istio sidecar自动注入过程分析
    filebeat-kafka日志收集
    istio路由配置
  • 原文地址:https://www.cnblogs.com/zqyanywn/p/6842091.html
Copyright © 2011-2022 走看看