window.open虽然在很多时候被广大中小站长用于弹窗广告的展示,所以广受争议,但是在业务需求中还是有很多场景需要用到此功能。然而,大多数浏览器对此都有一定的安全策略进行阻止,为此本文将针对以下浏览器进行测试。

Chrome16、Firefox10、360SE4.2、IE6、IE8

1、首先是最原始的在head标签中加入

<script>

window.open('about:blank');                            //空白页

window.open('http://www.1688.com/');   //非同源知名站点

window.open('http://www.ginano.net/');  //同源

window.open('http://www.aliren.org/');  //非同源非知名站点

alert('over!');

</script>

结果显示:Firefox、IE6、Chrome、360SE均阻止了弹出广告;360SE在加载时,从第一个open开始阻止了弹窗并且停止了后续代码的执行,连over都没有弹出(这样也行)。

2、在一个非a标签上执行click事件,然后触发行为

$('#not-a').click(function(){

window.open('http://www.1688.com/');

window.open('http://www.aliren.org/');

window.open('http://www.ginano.net/');

window.open('about:blank');

alert('over!');

});

<span id="not-a">dddd</span>

结果显示:除了IE和360SE不允许同时打开两个及以上弹窗外,其他浏览器都能够正常打开所有窗口,但是360SE居然同样阻止弹窗的同时停止后后续的脚本执行!!

3、在一个a标签上执行2中同样的操作,得出的结论一致,在此不再累述。同样从上面的测试中可见,对于打开多个窗口和打开单个窗口基本行为一致,只是在有些时候360SE这个号称安全的浏览器做了一些额外的处理而已,所以接下来的测试将会只针对一个弹窗进行测试。如果不同网址对应的弹窗行为不同将会做进一步说明。

4、很多时候我们会根据ajax请求返回的结果来执行window.open操作,那么这个时候还能顺利打开么?

$('#tag-a,#not-a').click(function(e){

e.preventDefault();

$.ajax({

//async:false,

url:'http://www.ginano.net/',

success:function(){

window.open('http://www.ginano.net/');

}

});

//return true;

});

<a href="http://www.ddddd.com" id="tag-a">testa</a>

<span id="not-a">testb</span>

结果很意外的,360SE居然都能够打开弹窗,而其他所有浏览器都一致的阻止了弹窗。

5、重复第4种情况的讨论,修改ajax请求为同步请求,看看什么反应。结果显示所有浏览器都能够正常打开弹窗,因此得出结论:同步的操作能够解除浏览器对弹窗的限制。

6、其实还有一种非常恶心的场景,当然可以采用其他方式避免。但是如果你又不得不这样做呢?还是得看一下吧:

如果想希望通过点击B的同时,使得某个链接A也被点击(好像大多数的广告需要被点击,许多垃圾站就这样做的),就需要用到此场景

$('#not-a').click(function(){

$('#tag-a').click();

});

<a href="http://www.ddddd.com" id="tag-a">test</a>

<span id="not-a">dddd</span>

而这种情况,所有浏览器都会对js触发的和鼠标触发的点击事件做出正确的判断,因此不会自动打开链接,从而影响垃圾站长们的心情。但是不急,从上面几个场景的分析可以很容易得到以下的解决方法,那就是给所需要的链接增加一个click的事件,然后通过click事件注册window.open来打开所需要的窗口:

$('#tag-a').click(function(){

e.preventDefault();

window.open($(this).attr('href'));

return false;

});

因此就可以实现变态的需求了。。。站长们偷着乐吧!(其实这种方法和直接在触发标签中添加window.open事件别无两样)

从上面的分析可见,浏览器对于鼠标点击和js触发点击是有不同的行为控制的,主要是需要判断标准为事件的触发起始必须为真实的鼠标事件,以及事件执行的连贯性。另外同时打开多个弹窗也会受到部分浏览器的安全屏蔽。所以,一开始就自动打开弹窗将会被阻止,而通过鼠标click事件来弹窗却可以正常打开;而ajax的异步操作同样会让浏览器认为其为非连贯性的鼠标点击事件,所以需要采用同步的请求来完成。

360浏览器拦截弹窗,window.open方式打不开新页面的更多相关文章

  1. 防止浏览器拦截的window.open新窗口方案

    背景 当前的浏览器为了保证用户体验,在很多场合下禁止了window.open打开新窗口,下面就给出一些方案,最大程度上的实现新窗口打开一个链接. 方案 //打开新链接方法实现 function win ...

  2. ajax请求后弹开新页面被浏览器拦截

    window.open()我想应该很多人都不陌生吧,它可以实现除用a标签以外来实现打开新窗口! 最近开发项目用到时,却遇到了麻烦,本来好好的弹出窗口,结果被浏览器无情的给拦截了! 代码如下: $.ge ...

  3. ajax回调中window.open弹出的窗口会被浏览器拦截的解决方法

    存在问题:处理页面ajax请求过程中,异步请求成功后需要新开窗口打开 url,使用的是 window.open() 方法 来实现,最终都被浏览器拦截了.不会跳到对应的页面,如下 原因:浏览器之所以拦截 ...

  4. window.open方法被浏览器拦截的处理方式

    问题现象 当我们在一个 ajax 回调中执行 window.open 方法时,新页面会被浏览器拦截. 原因 在 Chrome 的安全机制里,非用户直接触发的 window.open 方法,是会被拦截的 ...

  5. 【转载】window.open被浏览器拦截的解决办法

    今天在处理程序的过程中,发现window.open方法会被浏览器拦截,导致无法打开新页面,查阅相关资料后发现,主要原因是浏览器为了维护用户安全和体验,禁止在javascript中直接使用window. ...

  6. (转)js弹窗&返回值(window.open方式)

    本文转载自:http://hi.baidu.com/z57354658/item/5d5e26b8e9f42fa7ebba93d4 js弹窗&返回值(window.open方式) test.h ...

  7. window.open()被浏览器拦截问题汇总

    一.问题描述 最近在做项目的时候碰到了使用window.open被浏览器拦截的情况,虽然在自己的环境可以对页面进行放行,但是对用户来说,不能要求用户都来通过拦截.何况当出现拦截时,很多用户根本不知道发 ...

  8. window.open打开新窗口被浏览器拦截的处理方法

    一般我们在打开页面的时候, 最常用的就是用<a>标签,如果是新窗口打开就价格target="_blank"属性就可以了, 如果只是刷新当前页面就用window.loca ...

  9. 360浏览器下载excel问题解决方式

    亲们有没有碰到过今天我遇到的这件事. 如果使用简单的链接.或者get方式提交的表单,去下载excel,那么360浏览器就会有问题. 问题是:它没把我用java生成的excel表格下载,而是去把我的列表 ...

随机推荐

  1. HTML 事件

    1.HTML 全局事件属性 HTML4 的新特性之一就是可以使 HTML 事件触发浏览器中的行为,比方说当用户点击某个 HTML 元素时启动一段 JavaScript,在 HTML5 中还增加了一些新 ...

  2. 【javascript 函数基础知识】

    函数实际上是对象,每个函数都是 Function 类型的实例,而且都会与其他引用类型一样具有属性和方法.由于函数是对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定. [概念标签] ...

  3. 面试题:m个长度为n的ordered array,求top k 个 数字

    package com.sinaWeibo.interview; import java.util.Comparator; import java.util.Iterator; import java ...

  4. WPF中将四个数字字符串值(比如:"10,10,300,300")转为Rect

    RectConverter rectConverter = new RectConverter(); string parseString = viewportEntry.Text; if (pars ...

  5. 版本控制工具git入门

    版本控制工具的历史 不说了,放张图 两者的区别:集中式需要一个中心服务器放置最新的文件,需要联网操作.分布式可以再不联网的情况下操作,前提要拥有版本库 git安装  略 github注册 略 如何在g ...

  6. Ogre实现简单地形

    利用SimpleRenderable实现DirectX 9 3D 游戏设计入门中 第十三章 地形渲染基础的简单地形,只是简单的实现了地形的基本框架,顶点,索引,纹理等,为简单起见高度都为1,适合新手做 ...

  7. 一些Swift编程语言的相关资料

    苹果官方Swift文档<The Swift Programming Language> 苹果开发者Swift文档及介绍 中文版Apple官方Swift教程(Github协作翻译中) Git ...

  8. 当今app行业 比较流行的 简称 汇总

    B=Business,即企业:C=Customers,即消费者,这样就好理解这些简称了:M=Medium,即媒介B2B:(Business To Business)商家对商家进行交易 如:阿里巴巴.生 ...

  9. C# 合并DLL, 合并DLL进入EXE 【转】

    使用方法非常简单 在项目属性窗口中,选择"生成事件",在"生成后事件命令行"下的文本框中输入 ilmerge /ndebug /t:dll /log c:/1/ ...

  10. IronPython脚本调用C#dll示例

    上篇Python脚本调用C#代码数据交互示例(hello world)介绍了与C#紧密结合的示例,这里还将提供一个与C#结合更紧密的示例,直接调用C#编写的DLL.      我们还是沿用了上篇文章的 ...