Chrome 浏览器上的自动文件下载限制为 10 个文件

Chrome 浏览器上的自动文件下载限制为 10 个文件

最新推荐文章于 2025-04-10 15:49:47 发布

原创

最新推荐文章于 2025-04-10 15:49:47 发布

·

5.5k 阅读

·

2

·

3

·

CC 4.0 BY-SA版权

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

文章标签:

#javascript

#前端

该文描述了一个JavaScript解决方案,通过创建延时Promise来防止同时下载多个文件。在批量下载文件时,每个文件之间暂停1秒,确保下载的顺序性。利用Vue.js的store进行数据交互,通过创建a标签并模拟点击下载文件,同时使用URL.revokeObjectURL释放内存。

目前不知道是由于什么导致的,搜了不少内容也查找不到相关资料,不过如果还是想多个文件单独下载的话,可以使用延时1s的方式来解决。

// 暂停1s

pause() {

return new Promise((resolve) => {

let timer = setTimeout(resolve, 1000);

this.timerArr.push(timer); // 创建了定时器,放到一个数组中,最后将其清除掉。

});

},

// 批量下载

async batchDownload() {

// 获取需要下载的文件列表的单独文件ID

const finalArr = getFileItem(this.downloadList, this.dataList);

for (const key in finalArr) {

await this.pause();

await this.downloadFile(finalArr[key]);

}

},

// 下载文件

async downloadFile(single) {

const attachmentId = get(single, 'attachmentId');

await this.$store.dispatch('getDownloadUrlNew', attachmentId).then((res) => {

// 也可以使用window.open()方式下载

// window.open(res.content, '_self');

const link = document.createElement('a');

link.style.display = 'none';

link.href = res.content; // res.content为后端返回的文件的地址

document.body.appendChild(link);

link.click();

URL.revokeObjectURL(link.href);

document.body.removeChild(link);

});

},

友情链接:
Copyright © 2022 暴击魔方福利站 All Rights Reserved.