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>

  • 相关阅读:
    C#使用GZipStream压缩与解压字符串
    C# 参考之方法参数关键字:params、ref及out
    C#中cookie讲解
    WPF中窗口控件的跨线程调用
    vs2010 快捷键大全
    Python线程池
    Python 爬虫修正
    Python 爬虫插件
    Python发现爬虫插件有BUG。
    Python 存在BUG的线程池
  • 原文地址:https://www.cnblogs.com/zqyanywn/p/6842091.html
Copyright © 2011-2022 走看看