window.open在Safari浏览器出现的问题

回调函数(最常见的就是发送ajax请求成功或者失败回调函数)中使用 window.open时,在 Safari浏览器会无效,原因是Safari的安全机制将其阻挡了。

上有政策,下有对策,解决办法为:

假设使用了我在Vue中封装的 动态Axios配置 演示发送 post请求,其它使用回调函数的使用方法同理。
// 这个是模仿在Vue中,且使用了ES6,不使用则把let换为var便可
methods: {
   sendData() {
    let winOpen = window.open("", "_blank"); //首先打开一个新页面
    post("xx/xx/", data).then( res => {
        let link = res.link;
        setTimeout(function() {  //这里使用setTimeout非常重要,没有将无法实现
            //原因是window.open会中断正在执行的进程,这样能保证其它代码执行完成再执行这个。
          winOpen.location = link; //改变页面的location
        }, 100);
      }, err => {
        console.log(err.msg);
      })
  }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值