使用window.open 打开多个标签页,浏览器默认是禁止该行为的,浏览器会认为是广告等就会拦截。
注意
第一点,我们需要使用setTimeout 进行宏任务处理,因为短时间内打开多个标签页,浏览器依旧会拦截,最后只打开一个。
第二点:window.open的第二个参数必须是动态的,效果跟_blank是一样的
const urlList = ['https://www.baidu.com/','https://www.baidu.com/','https://www.baidu.com/']
urlList.forEach((item, index) => {
setTimeout(() => {
window.open(item, `one${index}`)
this.printOrderDialogShow = false
}, 0)
})
文档参考
此时运行代码,浏览器会弹窗该弹窗,我们要选择始终允许才可以。
如果大家不慎选择了继续拦截。我们则需要再设置-隐私和安全-弹出式窗口和重定向。找到域名,把权限修改为允许即可。