window.open在Safari中不能打开

大部分现代的浏览器(Chrome/Firefox/IE 10+/Safari)都默认开启了阻止弹出窗口的策略,缘由是window.open被广告商滥用,严重影响用户的使用。这个阻止弹出窗口的操做,并非直接封杀window.open(),而是会根据用户的行为来判断此次window.open()是否属于流氓操做。javascript

这些事件 handler 里的,但若是是代码本身触发的就会被阻止。java

那么,咱们能够知道,在Safari中没法open新窗口,缘由是Safari的安全机制将其阻挡。ajax

那么,若是咱们的需求是经过Ajax请求数据后,在成功的回调函数中open一个相关的窗口,显然正常手段是无法在Safari中搞定的。json

那么,如何解决该问题呢?很简单,直走不行绕着走,绕过这个安全机制,也就是说在你调用Ajax以前,先打开这个窗口,而后在回调函数里面修改打开窗口的location,这样就能够解决。浏览器

示例代码:安全

var openWin = function(){    var winRef = window.open("url","_blank");
    $.ajax({        type: '',        url: '',        data: '',
        ......
        success:function(json){
            winRef.location = "新的url";
        }
    });
};

  

不过,因为种种缘由,window.open()常常会被阻止掉,咱们能够根据window.open()的返回值来判断其执行状况,代码以下:函数

var winOpen = window.open("url",...);if(winOpen == null || typeof(winOpen) == 'undefined'){
    consoel.log("窗口没法打开,请检查浏览器!");
}else{
    consoel.log("窗口打开成功!");
}

  

这样的话,就能够在界面上比较清晰的告知用户是怎么回事了。

本文摘自:http://www.imooc.com/article/78876url

相关文章
相关标签/搜索