h5在safire中使用window.open()不能打开新页面

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

       如果是用户出发的动作所引起的window.open(),浏览器不会阻止。但是写在 onclick 这些事件 handler 里的,但如果是代码自己触发的就会被阻止。

       那么,在safire中无法打开open新窗口,是因为safire的安全机制将其阻挡。只要不是用户发起的操作的都会被阻止。

解决方法:

 

1,window.location.replace()  但是不能打开新窗口

2,回调函数中生成一个链接,让用户点击一下

3,在回调函数之前加一个新窗口,然后再回调函数中设置他的location

 

      var winRef = window.open('','_blank');
      this.$axios
        .post("url", {
          resource_id: resource_id,
        })
        .then((res) => {
          if (res.code == 200) {           
            winRef.location = res.data.playbackUrl;
            
          }
        });

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值