zoukankan      html  css  js  c++  java
  • window.open在Safari中不能打开

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

    这些事件 handler 里的,但如果是代码自己触发的就会被阻止。

    那么,我们可以知道,在Safari中无法open新窗口,原因是Safari的安全机制将其阻挡。

    那么,如果我们的需求是通过Ajax请求数据后,在成功的回调函数中open一个相关的窗口,显然正常手段是没法在Safari中搞定的。

    那么,如何解决该问题呢?很简单,直走不行绕着走,绕过这个安全机制,也就是说在你调用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/78876

  • 相关阅读:
    [组件封装] 微信小程序
    发布一个npm包(webpack loader)
    深入理解JavaScript隐式类型转换(详解 +
    通过nginx代理之后,获取客户端ip
    IntelliJ Idea 常用快捷键列表
    Example For maven-compiler-plugin
    maven 使用tomcat插件 自动化部署war
    jsoup: Java HTML Parser (类似jquery)
    Export Data from mysql Workbench 6.0
    安装openJDK 8
  • 原文地址:https://www.cnblogs.com/handsome-jm/p/11341645.html
Copyright © 2011-2022 走看看