IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> window.open(url)多次打开下载链接被浏览器拦截问题解决方案,js实现循环访问多个下载链接 -> 正文阅读

[JavaScript知识库]window.open(url)多次打开下载链接被浏览器拦截问题解决方案,js实现循环访问多个下载链接

背景

项目背景就是用户存在多个数据链接,想要通过前端js点击一次下载就将这几个数据都下载下来。

起初设计代码:

//len为urllist中链接个数
//urlspec为另外独特的一种数据链接

for (var i = 0; i < len; i++) {
    window.open("" + urllist[i]);
}
return window.open("" + urlspec);

运行后下载数据,发现仅下载了urlspec的数据,其他的被浏览器拦截了,需要用户自己手动允许才开始下载。

原因和尝试

检索后了解:某些浏览器(比如Chrome)出于安全和体验的考虑,会禁止直接在JS中使用 window.open(url) 打开新的窗口。但是如果使用 window.open(url,'_self') 改变当前窗口是允许的。
禁止直接打开的原因就是非用户操作产生的新弹出窗口,会被认为这可能是一个广告,所以禁止了这种行为。但是在开发的时候, 有时候又的确存在需要使用的场景。从浏览器客户端来看,可以在浏览器客户端设置, 但是这种方式只能临时或单个机器解决。

网上总结主要的解决方法:1、使用表单提交方式;2、使用标签 <a>或是按钮的onclick 事件;3、延迟打开;4、先打开页面, 再更改地址;5、先弹出窗口,然后重定向等等。具体的相关内部实现案例参考:window.open(url)打开链接被浏览器拦截解决方案 - 走看看 (zoukankan.com)window.open被浏览器拦截的解决方案_XiaoHuBeiPlus的博客-CSDN博客

?尝试用这些方法解决:均不能实现

1、使用标签 <a>或是按钮的onclick 事件(仍有拦截

for (var i = 0; i < len; i++) {

    var a = document.createElement('a');
    a.setAttribute('href', urllist[i]);
    a.setAttribute('style', 'display:none');
    a.setAttribute('target', '_blank');
    document.body.appendChild(a);
    a.click();
    a.parentNode.removeChild(a);//依旧不行,还会被拦截
}
return window.open("" + urlspec);

2、使用延时(没有下载

for (var i = 0; i < len; i++) {
    setTimeout('window.open("" + urllist[i]);',1000);//该方法不行,直接无下载
}
return window.open("" + urlspec);

解决方法

最后检索了解到多个url文件下载文章中使用的iframe就可以实现这样的场景:

var count=0;
for (var i = 0; i < len; i++) {
  var hiddenIFrameID = 'hiddenDownloader' + count++;
  var iframe = document.createElement('iframe');
  iframe.id = hiddenIFrameID;
  iframe.style.display = 'none';
  document.body.appendChild(iframe);
  iframe.src = urllist[i];//直接下载,不会弹出新的页面
}
return window.open("" + urlspec);

?????????这样就解决了以上问题,大家在实际使用中还是需要根据自己项目功能需要采用自己最简单的解决方法。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-14 22:29:05  更:2022-06-14 22:32:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 11:13:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码