调用支付宝网页支付被浏览器拦截

问题:在开发网页支付宝支付业务时,调用支付宝的返回的是一个完整的html页面,浏览器误认为是广告类窗口进行拦截屏蔽。

解决办法:主动触发打开新的标签页

// 生成订单号,跳转项目空页面渲染支付宝返回的完整页面
generateOrderNo() { 
   // 开启一个新的标签页
   const newWin = window.open('about:blank'); 
   this.$http.post(userSelfUrl + '/order', this.itemsInfo).then((res) => { 
     if (res.data.ecode == ResEcode) { 
        const resData = res.data.data 
        const data = { orderNo: resData.orderNo, rechargeType: 1 } 
        const {href} = this.$router.resolve({ name: 'Alipay', query: data }) 
        const url = 'http://' + window.location.host + '/' + href 
        // 重定向url到项目中的空页面
        newWin.location.href = url 
        } else { 
          this.responseText = res.data.msg 
        } 
    }) 
}

// 支付组件

当然还有其他更好的办法,仅供参考
 

你可能感兴趣的:(JavaScript,弹窗拦截,Javascript,支付宝支付)