js 动态创建a href 循环下载文件只能下载10个或者固定数目的问题

在web前端项目中,很多地方的下载单张图片/文件都可以用<a href="/images/logo.png" download="文件名">来下载指定文件

遇到的问题: 

在下载多个文件的时候 使用for 循环来触发 a href  download (此批量下载方法当然不推荐 很lowB 也体验不好 只是偶尔发现此问题 )

//for循环来触发a href 下载文件
for(let i=0;i<=100;i++){
   // 获取要下载的图片dom
   var img = document.getElementsByClassName('qrcode_canvas')[i]; 
   //获取地址
   var url = img.src;
   var a = document.createElement('a');
   //模拟点击
   var event = new MouseEvent('click');   
   a.download="xxxxx.png";
   a.dispatchEvent(event);    
}

1.此方法在mac的电脑上的chrome 上,不论怎么操作,不管是mac笔记本 8GB16GB运行内存的,还是iMac 一体机16GB内存的 都只能下载 10 张(浏览器也没有报任何错误的log信息 显然不是内存问题)

2.而在window 系统上的chrome 上却没有发现限制,超过10张是可以正常下载的

 

目前并没有找到具体问题的原因,只能是在现在单个文件时候 可以通过a href download 来下载,下载多个文件的时候用三方插件(主要用到 jszip 和 file-saver 直接下载多个文件的zip压缩文件)

npm install jszip --save
npm install file-saver --save

拓展

https://blog.csdn.net/wzp6010625/article/details/100918051

目前此现象只发生在mac OS系统上

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值