公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

【JavaScript】WEB頁面純JS實現批量下載文件為壓縮包

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

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

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/[email protected]']; // 這里可以替換為自己的邏輯,比如從哪里獲取之類的

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 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 高h猛烈失禁潮喷a片在线播放 | 成年无码动漫av片在线观看 | 精品国产高清一区二区久久91 | 国产欧美日韩va另类在线 | 91人妻人人做人碰人人爽 | 国产av激情久久无码天堂 | 国产真实愉拍系列在线视频 | 国产高清在线观看一区二区三区 | 91tv成人精品人 | 国产av综合精品色区 | 成人午夜黄网站在 | 成人片在线 | 国产v片在线播放 | 精品亚洲免费视频91 | 加勒比色老久久综合网 | 国产精品一区二区久久宅男 | 国产超清无码一级内射视频 | 国产aⅴ无码久久丝袜美腿 国产aⅴ无码专区 | 国产在线观看精品福利片 | 国产一区二区三区免费大片天美 | 91乱码人妻精品一区二区三 | 黑人巨大精品一区二区在线 | 97人妻天天摸天天爽天天 | 91精品国产麻豆福利在线电影 | 国产综合亚洲欧美日韩一区二区 | 国产高清重口变态sm在线观看 | 精品国产aⅴ一区二区三区v免费 | 国产综合精品婷婷丁香久久 | 国产亚洲漂亮白嫩美女在线 | 2025国产亚洲日韩在线 | 成人午夜福利在线观看 | 精品久久福利一区二区 | 国产高清免费观看a∨片 | 国产精品一区二区久久蜜臀内射 | 国产妇女馒头高清 | 国产成人av免观看 | 国产极品高清在线播放 | 国产一区二区在线免费观看 | 18禁白丝喷水视频www视 | 国产尤物在线观看一区二区 | 国产成人综合久久免费精品 |