window.open在safari浏览器跳转被拦截问题

67 篇文章 0 订阅

解决方法:

 async getToken(row) {
      // 兼容safari浏览器跳转拦截
      let tempwindow = window.open()
      try {
        const params = {
          uid: row.id,
        }
        const res = await this.$api.getAdminLoginToken(params)
        if (res.code === 0) {
          this.adminLoginToken = res.data.atoken
          /**
            * match是匹配当前环境,如:
            * st1环境的值 : st1
            * st2环境的值 : st2环境的值
            * 生产环境的值: youke-syh
            * 需要根据match匹配的当前环境,从优客管理端后台跳转到--->对应的优客平台前端
          */
          const match = (document.domain.match(/([^.*]+).2345.cn/) || ['', 'st1'])[1]
          const urlMap = {
            st1: `http://xxx/#/user/auth?token=${this.adminLoginToken}`,
            st2: `http://xxx/#/user/auth?token=${this.adminLoginToken}`,
            st3: `http://xxx/#/user/auth?token=${this.adminLoginToken}`,
            st4: `http://xxx/#/user/auth?token=${this.adminLoginToken}`,
            'youke-syh': `xxx/#/user/auth?token=${this.adminLoginToken}`
          }
          tempwindow.location = urlMap[match]
        }
      } catch (error) {
        console.log(error)
      }
    },

注意坑:

如果是在 异步请求成功以后跳转,window.open要放在外面,不能写在异步成功的回调里面

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用`window.open`方法打开一个新窗口,有浏览器拦截这个操作,阻止新窗口的打开。这是因为浏览器内置了一些安全机制,旨在防止恶意弹窗和广告等不受用户控制的行为。 浏览器拦截`window.open`的主要原因可能包括以下几点: 1. 弹窗拦截浏览器拦截那些未经用户交互而直接打开的新窗口,以防止恶意网站滥用弹窗功能。这是为了保护用户免受不必要的干扰和潜在的安全风险。 2. 广告拦截:一些浏览器会自动屏蔽那些被认定为广告的弹窗。这些浏览器会根据广告过滤规则或者用户自定义的设置来判断哪些弹窗是广告,并将其拦截。 3. 浏览器设置:用户可能在浏览器的设置中主动选择了阻止弹窗的选项,这样浏览器就会拦截`window.open`方法打开的新窗口。 如果你希望绕过浏览器拦截,可以尝试以下方法: 1. 触发`window.open`方法的操作必须是由用户主动触发的,例如在点击事件中调用`window.open`方法。这样可以避免被浏览器拦截。 2. 检查浏览器的弹窗拦截设置,确保它没有被启用或者将你的网站添加到白名单中。 3. 使用浏览器提供的替代方法,例如`window.location.href`来打开新的URL,或者使用`<a>`标签的`target="_blank"`属性来实现类似的功能。 请注意,绕过浏览器拦截机制可能会违反用户的期望和浏览器的安全策略。因此,在进行任何操作之前,请确保你的意图是合法和符合用户体验的。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值