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);
      })
  }
}

猜你喜欢

转载自blog.csdn.net/isLooge/article/details/84024443