开不了的窗_____window.open

Posted 潇湘待雨

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了开不了的窗_____window.open相关的知识,希望对你有一定的参考价值。

   window.open()是原来常用的新开窗口的方式,但是呢,现在会被大多数浏览器阻止掉,默认为是非用户意愿的打开窗口,即广告之类的。

但是通过a链接的事件来open是可以的,因为这样会认为是用户主观的要打开另一个窗口所以不予以拦截。

   关于如何解决被阻止的问题,网上有很多种方式,一直未加以实践。前段时间项目中存在这样的需求,当时使用了几种方式,但是未生效,最后

通过延迟更改location的方式终于解决掉了。下面结合实际讨论一下。

   1.a标签的直接事件,不会被拦截。代码如下: 

    links.on(‘click‘, function (e) {
  e.preventDefault();
  var _this = $(this);
  window.open(‘/bookmerchant/fun/‘);
  }

   2.ajax 请求之后,进行新开窗口的操作会被拦截掉,即使是a链接出发的事件。如下:

  self.addBtn.on(‘click‘, function (e) {
  /*ajax请求略去*/
}).on(‘success‘, function (res) {
if (res.code == 200) {
var cusId = res.data.customerId;
window.open(‘/bookmerchant/fun/‘);
  }。
此时的window.open()是不可行的。
网上看到的解决措施:
1.创建a标签然后,绑定事件,然后js触发。这种在我的实际操作中是同样被拦截的。
2.在请求之前新开标签window.open();然后请求接受之后更改location,这样是可以的。
var newTab=window.open(‘about:blank‘);
/*ajax请求*/
}).on(‘success‘, function (res) {
if (res.code == 200) {
newTab.location.href=‘/bookmerchant/fun‘;
}
3.还有一种方式是新开标签window.open(),然后通过setTimeout()来延迟设置location,原理相同应该也是可行的(此处未实践,所以不敢说一定)。
4.通过form提交的方式进行跳转,同样未实践,不加评论。只是拿出来给大家一种提醒。

         

以上是关于开不了的窗_____window.open的主要内容,如果未能解决你的问题,请参考以下文章

window.open 目标_self v window.location.href?

window.open 目标_self v window.location.href?

在 Chrome 中使用目标“_blank”打开 window.open

chrome window.open(url '_blank') 打开新窗口

打开新窗口(window.open) 用法

window.open怎么打开多个窗口