LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

【JavaScript】WEB頁面純JS實(shí)現(xiàn)批量下載文件為壓縮包

admin
2023年8月24日 21:44 本文熱度 862

有一個需求,是列表里面有很多圖片或者pdf文件的url,用戶想要一個批量下載,點(diǎn)擊按鈕后,把列表的這些文件全部都下載下來,并且是一個壓縮包,包里面包含那些url對應(yīng)的文件。

1.  <!doctype html>

2.  <html lang="en">

3.  <head>

4.  <meta charset="UTF-8">

5.  <title>doc</title>

6.  </head>

7.  <body>

8.   <button onclick='packageImages()'>批量下載</button>

9.   

10.<!-- 下面是需要用到的js -->

11.<script src="https://cdn.staticfile.org/jquery/3.6.1/jquery.min.js"></script>

12.<script src="https://cdn.staticfile.org/jszip/3.10.1/jszip.min.js"></script>

13.<script src="https://cdn.staticfile.org/FileSaver.js/2.0.5/FileSaver.min.js"></script>

14.<script src="https://cdn.staticfile.org/axios/1.2.0/axios.min.js"></script>

15.

16.<script>

17.   function packageImages() {

18.      var imgsSrc = ['https://img-home.csdnimg.cn/images/20201124032511.png', 'https://csdnimg.cn/medal/qixiebiaobing4@240.png']; // 這里可以替換為自己的邏輯,比如從哪里獲取之類的

19.

20.      var promises =[]

21.      const zip = new JSZip();

22.      for(let item of imgsSrc){

23.          let axios = getFile(item).then(({data})=>{

24.             let fileName = getFileName(item) //文件名

25.             zip.file(fileName, data, {binary: true});

26.          })

27.          promises.push(axios)

28.      }

29.

30.      Promise.all(promises).then(() => {

31.          if (Object.keys(zip.files).length > 0) {

32.             zip.generateAsync({type: 'blob'}).then((blob) => {

33.                 saveAs(blob, 'files.zip');

34.                 console.log('批量下載成功')

35.             });

36.          } else {

37.             console.log('下載全部失敗')

38.          }

39.      });

40.     }

41.    

42.     function getFileName(filePath){

43.      var startIndex = filePath.lastIndexOf("/");

44.      if(startIndex != -1)

45.          return filePath.substring(startIndex+1, filePath.length).toLowerCase();

46.      else return "";

47.     }

48.

49.     function getFile(url){

50.      return new Promise((resolve, reject) => {

51.                 axios({

52.                    url,

53.                    method: 'GET',

54.                    responseType: 'blob',

55.                 })

56.                 .then((data) => {

57.                    resolve(data);

58.                 })

59.                 .catch((err) => {

60.                    reject(err.toString());

61.                 });

62.      });

63.     }

64.</script>

65.</body>

66.</html>


該文章在 2023/8/24 21:47:05 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財務(wù)費(fèi)用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
在线中文字幕亚洲无线码 | 色七七在线免费观看视频 | 一本久久sm热国产片 | 中国日本免费不卡在线中文 | 亚洲人成影院在线高清 | 中日韩精品视频在线观看 |