前端 JavaScript 中快速發起多個下載請求時,解決瀏覽器的并發下載連接限制

為什么會漏掉鏈接?

當你在前端 JavaScript 中快速發起多個下載請求時,瀏覽器可能無法同時處理所有請求,導致一些請求被忽略。這通常與瀏覽器的并發連接限制有關,例如 Chrome 可能限制每秒下載 10 個文件。

如何避免漏掉鏈接?
  • 引入延遲: 你可以在每次下載請求之間添加約 333 毫秒的延遲,確保請求逐個處理。
  • 使用 JSZip: 另一種方法是使用 JSZip 庫將所有文件打包成一個壓縮文件,然后下載這個壓縮文件,這樣只需發起一個下載請求,減少漏掉的風險。
代碼示例

延遲方法:

const urls = [...]; // 文件 URL 數組
const delay = 333; // 約 1/3 秒延遲for (let i = 0; i < urls.length; i++) {const a = document.createElement('a');a.href = urls[i];a.download = true; // 或指定文件名a.style.display = 'none';document.body.appendChild(a);setTimeout(() => {a.click();document.body.removeChild(a);}, i * delay);
}

JSZip 方法:
首先引入 JSZip 庫:

<script src="https://cdn.skypack.dev/jszip@3.10.1"></script>

然后使用以下代碼:

const urls = [...]; // 文件 URL 數組
const zip = new JSZip();async function batchDownload() {for (let url of urls) {const response = await fetch(url);const blob = await response.blob();const filename = url.split('/').pop();zip.file(filename, blob);}const content = await zip.generateAsync({ type: 'blob' });saveAs(content, 'downloads.zip');
}batchDownload();
意外的細節

Firefox 在處理批量下載時可能表現不同,延遲方法可能無效(具體沒有嘗試),建議使用 JSZip 來確保所有文件都被包含。


詳細講解

問題背景

用戶報告在批量下載時,總是會漏掉后面的幾個下載鏈接。這表明在快速發起多個下載請求時,瀏覽器可能無法處理所有請求,導致一些鏈接被忽略。可能的原因為瀏覽器對并發 HTTP 連接的限制,例如 Chrome 可能限制每秒下載 10 個文件(Chrome/Chromium limits the number of download to a maximum of 10 per second)。此外,不同瀏覽器(如 Firefox)可能有不同的行為,增加了復雜性。

解決方案分析

為了解決這個問題,我們考慮了兩種主要方法:引入延遲和使用 JSZip 創建壓縮文件。

方法 1:引入延遲

通過在每次下載請求之間添加延遲,可以逐個處理請求,避免瀏覽器因并發限制而忽略某些請求。研究表明,約 333 毫秒的延遲(約 1/3 秒)在 Chrome 和 Opera 中有效(Stack Overflow: How in JS to download more than 10 files in browser including Firefox)。

  • 實現方式: 使用 setTimeout 在循環中為每個下載請求添加延遲。例如:
    const urls = [...]; // 文件 URL 數組
    const delay = 333; // 約 1/3 秒延遲for (let i = 0; i < urls.length; i++) {const a = document.createElement('a');a.href = urls[i];a.download = true; // 或指定文件名a.style.display = 'none';document.body.appendChild(a);setTimeout(() => {a.click();document.body.removeChild(a);}, i * delay);
    }
    
  • 優點: 簡單直接,適用于大多數瀏覽器,特別是在 Chrome 和 Opera 中。
  • 局限性: 在 Firefox 中可能無效,具體表現因瀏覽器版本和配置而異。
方法 2:使用 JSZip 創建壓縮文件

另一種方法是使用 JSZip 庫將所有文件打包成一個壓縮文件,然后下載這個壓縮文件。這樣只需發起一個下載請求,徹底避免了并發請求的問題。JSZip 是一個 JavaScript 庫,允許在瀏覽器中創建、讀取和編輯 .zip 文件(JSZip Documentation)。

  • 實現方式:
    首先引入 JSZip 庫:
    <script src="https://cdn.skypack.dev/jszip@3.10.1"></script>
    
    然后使用以下代碼:
    const urls = [...]; // 文件 URL 數組
    const zip = new JSZip();async function batchDownload() {for (let url of urls) {const response = await fetch(url);const blob = await response.blob();const filename = url.split('/').pop();zip.file(filename, blob);}const content = await zip.generateAsync({ type: 'blob' });saveAs(content, 'downloads.zip');
    }batchDownload();
    
  • 優點: 提供跨瀏覽器一致性,特別是在 Firefox 中表現更好(Stack Overflow: How in JS to download more than 10 files in browser including Firefox)。用戶只需下載一個文件,體驗更佳。
  • 局限性: 需要先通過 AJAX 加載所有文件,可能對大文件造成內存壓力,且需要確保文件可通過 AJAX 訪問(同域或配置 CORS)。
瀏覽器差異與注意事項
  • Chrome 和 Opera: 通常限制每秒 10 個下載,延遲方法有效(Chrome/Chromium limits the number of download to a maximum of 10 per second)。
  • Firefox: 延遲方法可能無效,建議使用 JSZip。Firefox 對 File System API 的支持有限,可能影響大文件下載(MEGA Help Centre: What are the file size limitations when downloading using my browser?)。
  • 并發連接限制: 瀏覽器對每個域的并發連接數有限制,通常為 4-6 個(Stack Overflow: max number of concurrent file downloads in a browser?),這可能導致快速發起的請求被隊列化或忽略。
性能與用戶體驗考慮
  • 延遲方法: 適合文件數量不多且用戶愿意等待的情況。延遲過長可能影響用戶體驗,建議從 333 毫秒開始測試。
  • JSZip 方法: 適合文件數量多或跨瀏覽器兼容性要求高的場景。但對于大文件,內存使用可能成為瓶頸,需注意瀏覽器內存限制(Stack Overflow: Is there any limit to filesize while downloading through browser over http)。
對比表
方法適用場景優點局限性
引入延遲Chrome、Opera,文件數量少簡單直接,易于實現Firefox 可能無效,延遲可能影響體驗
使用 JSZip跨瀏覽器,文件數量多單一下載請求,體驗更好需要 AJAX 訪問,內存占用可能高
結論與建議

引入延遲是解決批量下載漏掉鏈接的直接方法,建議從 333 毫秒開始測試,適用于 Chrome 和 Opera。對于 Firefox 或需要更高可靠性的場景,推薦使用 JSZip 創建壓縮文件,確保所有文件被包含。用戶應根據文件大小、數量和瀏覽器環境選擇合適的方法。

關鍵引用
  • Chrome/Chromium limits the number of download to a maximum of 10 per second
  • [Stack Overflow: How can I let a user download multiple files when a button is clicked?](https://stackoverflow.com/questions/18451856/how-can-i-let-a-user-download-multiple-files when-a-button-is-clicked)
  • Stack Overflow: How in JS to download more than 10 files in browser including Firefox
  • JSZip Documentation
  • MEGA Help Centre: What are the file size limitations when downloading using my browser?
  • Stack Overflow: max number of concurrent file downloads in a browser?
  • Stack Overflow: Is there any limit to filesize while downloading through browser over http

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/73247.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/73247.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/73247.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何修改桌面圖標——文件夾圖標(Windows 10)

修改文件夾圖標 EX&#xff1a;新建文件夾&#xff0c;程序創建文件夾等 修改桌面文件夾圖標&#xff0c;打開右鍵菜單功能項&#xff0c;點擊“屬性” 在屬性窗口頁面找到并單擊自定義&#xff0c;然后點擊“更改圖標” 從列表中選擇喜歡的圖標&#xff0c;或點擊瀏覽選擇個…

LiveCommunicationKit OC 實現

一、實現效果: ? LiveCommunicationKit?是蘋果公司在iOS 17.4、watchOS 10.4和visionOS 1.1中引入的一個新框架,旨在優化VoIP通話的交互體驗。該框架提供了與

基于Bert模型的增量微調3-使用csv文件訓練

我們使用weibo評價數據&#xff0c;8分類的csv格式數據集。 一、創建數據集合 使用csv格式的數據作為數據集。 1、創建MydataCSV.py from torch.utils.data import Dataset from datasets import load_datasetclass MyDataset(Dataset):#初始化數據集def __init__(self, s…

flowable新增或修改單個任務的歷史變量

簡介 場景&#xff1a;對歷史任務進行關注&#xff0c;所以需要修改流程歷史任務的本地變量 方法包含2個類 1&#xff09;核心方法&#xff0c;flowable command類&#xff1a;HistoricTaskSingleVariableUpdateCmd 2&#xff09;執行command類&#xff1a;BpmProcessCommandS…

Netty基礎—4.NIO的使用簡介一

大綱 1.Buffer緩沖區 2.Channel通道 3.BIO編程 4.偽異步IO編程 5.改造程序以支持長連接 6.NIO三大核心組件 7.NIO服務端的創建流程 8.NIO客戶端的創建流程 9.NIO優點總結 10.NIO問題總結 1.Buffer緩沖區 (1)Buffer緩沖區的作用 (2)Buffer緩沖區的4個核心概念 (3)使…

python元組(被捆綁的列表)

元組&#xff08;tuple&#xff09; 1.元組一旦形成就不可更改,元組所指向的內存單元中內容不變 定義&#xff1a;定義元組使用小括號&#xff0c;并且使用逗號進行隔開&#xff0c;數據可以是不同的數據類型 定義元組自變量&#xff08;元素&#xff0c;元素&#xff0c;元素…

輸入:0.5元/百萬tokens(緩存命中)或2元(未命中) 輸出:8元/百萬tokens

這句話描述了一種 定價模型&#xff0c;通常用于云計算、API 服務或數據處理服務中&#xff0c;根據資源使用情況&#xff08;如緩存命中與否&#xff09;來收費。以下是對這句話的詳細解釋&#xff1a; 1. 關鍵術語解釋 Tokens&#xff1a;在自然語言處理&#xff08;NLP&…

計算機視覺算法實戰——駕駛員玩手機檢測(主頁有源碼)

?個人主頁歡迎您的訪問 ?期待您的三連 ? ?個人主頁歡迎您的訪問 ?期待您的三連 ? ?個人主頁歡迎您的訪問 ?期待您的三連? ? ??? 1. 領域簡介&#xff1a;玩手機檢測的重要性與技術挑戰 駕駛員玩手機檢測是智能交通安全領域的核心課題。根據NHTSA數據&#xff0…

Java糊涂包(Hutool)的安裝教程并進行網絡爬蟲

Hutool的使用教程 1&#xff1a;在官網下載jar模塊文件 Central Repository: cn/hutool/hutool-all/5.8.26https://repo1.maven.org/maven2/cn/hutool/hutool-all/5.8.26/ 下載后綴只用jar的文件 2&#xff1a;復制并到idea當中&#xff0c;右鍵這個模塊點擊增加到庫 3&…

深度學習項目--基于DenseNet網絡的“乳腺癌圖像識別”,準確率090%+,pytorch復現

&#x1f368; 本文為&#x1f517;365天深度學習訓練營 中的學習記錄博客&#x1f356; 原作者&#xff1a;K同學啊 前言 如果說最經典的神經網絡&#xff0c;ResNet肯定是一個&#xff0c;從ResNet發布后&#xff0c;很多人做了修改&#xff0c;denseNet網絡無疑是最成功的…

優化用戶體驗:關鍵 Web 性能指標的獲取、分析、優化方法

前言 在當今互聯網高速發展的時代用戶對于網頁的加載速度和響應時間越來越敏感。一個性能表現不佳的網頁不僅會影響用戶體驗&#xff0c;還可能導致用戶流失。 因此&#xff0c;了解和優化網頁性能指標是每個開發者的必修課。今天我們就來聊聊常見的網頁性能指標以及如何獲取這…

vs code配置 c/C++

1、下載VSCode Visual Studio Code - Code Editing. Redefined 安裝目錄可改 勾選創建桌面快捷方式 安裝即可 2、漢化VSCode 點擊確定 下載MinGW 由于vsCode 只是一個編輯器&#xff0c;他沒有自帶編譯器&#xff0c;所以需要下載一個編譯器"MinGW". https://…

Kotlin關鍵字`when`的詳細用法

Kotlin關鍵字when的詳細用法 在Kotlin中&#xff0c;when是一個強大的控制流語句&#xff0c;相當于其他語言中的switch語句&#xff0c;但更加強大且靈活。本文將詳細講解when的用法及其常見場景&#xff0c;并與Java的switch語句進行對比。 一、基本語法 基本的when語法如…

MFCday01、模式對話框

對話框類和應用程序類。 MFC中 Combo Box List Box List Control三種列表控件&#xff0c;日期控件Date Time Picker

接口測試筆記

4、接口測試自動化 接口自動化概述 HttpClient HttpClient開發過程 創建Java工程 新建libs庫目錄 HttpClient 工具下載及引入 https://hc.apache.org/index.html工程中引入jar包 Get請求 HttpGet方法---發起Get請求 創建HttpClient對象 CloseableHttpClient httpclient …

查找sql中涉及的表名稱

import pandas as pd import datetime todaystr(datetime.date.today())filepath/Users/kangyongqing/Documents/kangyq/202303/分析模版/sql表引用提取/ file101試聽課明細.txt newfilefile1.title().split(.)[0]with open(filepathfile1,r) as file:contentfile.read().lower…

如何在Ubuntu上構建編譯LLVM和ISPC,以及Ubuntu上ISPC的使用方法

之前一直在 Mac 上使用 ISPC&#xff0c;奈何核心/線程太少了。最近想在 Ubuntu 上搞搞&#xff0c;但是 snap 安裝的 ISPC不知道為什么只能單核&#xff0c;很奇怪&#xff0c;就想著編譯一下&#xff0c;需要 Clang 和 LLVM。但是 Ubuntu 很搞&#xff0c;他的很多軟件版本是…

【Spring IOC/AOP】

IOC 參考&#xff1a; Spring基礎 - Spring核心之控制反轉(IOC) | Java 全棧知識體系 (pdai.tech) 概述&#xff1a; Ioc 即 Inverse of Control &#xff08;控制反轉&#xff09;&#xff0c;是一種設計思想&#xff0c;就是將原本在程序中手動創建對象的控制權&#xff…

電感與電容的具體應用

文章目錄 一、電感應用1.?電源濾波&#xff1a;2. 儲能——平滑“電流波浪”? ?3. 調諧——校準“頻率樂器”?4. 限流——防止“洪水災害”?二、電容應用1.核心特性理解2.應用場景 三.電容電感對比 一、電感應用 1.?電源濾波&#xff1a; ?場景&#xff1a;工業設備中…

前端面試:axios 請求的底層依賴是什么?

在前端開發中&#xff0c;Axios 是一個流行的 JavaScript 庫&#xff0c;用于發送 HTTP 請求。它簡化了與 RESTful APIs 的交互&#xff0c;并提供了許多便利的方法與配置選項。要理解 Axios 的底層依賴&#xff0c;需要從以下幾個方面進行分析&#xff1a; 1. Axios 基于 XML…