精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript 如何壓縮目錄并上傳?

開發 前端
在日常工作中,文件上傳是一個很常見的功能。在上傳文件時,我們可以選擇上傳單個文件,也可以通過設置 multiple 屬性來上傳多個文件。

 [[398931]]

本文轉載自微信公眾號「全棧修仙之路」,作者阿寶哥。轉載本文請聯系全棧修仙之路公眾號。

在日常工作中,文件上傳是一個很常見的功能。在上傳文件時,我們可以選擇上傳單個文件,也可以通過設置 multiple 屬性來上傳多個文件。

本文阿寶哥將介紹如何上傳目錄及如何壓縮目錄并上傳,壓縮目錄的功能是通過 JSZip 這個庫來實現。利用這個庫還可以實現在線預覽 ZIP 文件的功能,感興趣的小伙伴可以閱讀 JavaScript 如何在線解壓 ZIP 文件? 這篇文章。下面我們先來介紹如何實現壓縮目錄并上傳的功能。

一、瀏覽器端

1.1 選擇目錄

在瀏覽器端,要實現壓縮目錄并上傳的功能。首先我們要先實現選擇目錄的功能,要實現該功能,我們可以直接使用 HTMLInputElement 元素的 webkitdirectory 屬性:

  1. <input type="file" id="uploadFile" webkitdirectory /> 

當設置了 webkitdirectory 屬性之后,我們就可以選擇目錄了。當阿寶哥選擇了 useAxios 目錄之后,就會顯示以下確認框:

點擊上傳按鈕之后,我們就可以獲取文件列表。列表中的文件對象上含有一個 webkitRelativePath 屬性,用于表示當前文件的相對路徑。在進行目錄壓縮的時候,我們就會使用到該屬性。

雖然通過 webkitdirectory 屬性可以很容易地實現選擇目錄的功能,但在實際項目中我們還需要考慮它的兼容性。比如在 IE 11 以下的版本就不支持該屬性,其它瀏覽器的兼容性如下圖所示:

(圖片來源 —— https://caniuse.com/?search=webkitdirectory)

1.2 壓縮目錄

在 JavaScript 如何在線解壓 ZIP 文件? 這篇文章中,阿寶哥介紹了在瀏覽器端如何使用 JSZip 這個庫實現在線解壓 ZIP 文件的功能。JSZip 這個庫除了可以解析 ZIP 文件之外,它還可以用來創建和編輯 ZIP 文件。這里阿寶哥基于 JSZip 庫提供的 API,封裝了一個 generateZipFile 函數:

  1. function generateZipFile( 
  2.   zipName, files, 
  3.   options = { type: "blob", compression: "DEFLATE" } 
  4. ) { 
  5.   return new Promise((resolve, reject) => { 
  6.     const zip = new JSZip(); 
  7.     for (let i = 0; i < files.length; i++) { // 添加目錄中包含的文件 
  8.       zip.file(files[i].webkitRelativePath, files[i]); 
  9.     } 
  10.     zip.generateAsync(options).then(function (blob) { // 生成zip文件 
  11.       zipName = zipName || Date.now() + ".zip"
  12.       const zipFile = new File([blob], zipName, { 
  13.         type: "application/zip"
  14.       }); 
  15.       resolve(zipFile); 
  16.     }); 
  17.   }); 

在以上代碼中,我們使用 file(name, data [,options]) 方法,把目錄中的文件依次添加到 zip 對象中,然后再通過 generateAsync 方法來生成 ZIP 文件。在生成 ZIP 文件時,我們可以設置該文件的類型。這里我們設置的默認類型為 blob 類型,除了支持 blob 類型之外,它還支持 base64、uint8array 和 arraybuffer 等類型。

1.3 上傳壓縮 ZIP 文件

在壓縮目錄生成 ZIP 文件之后,我們就可以通過 XMLHttpRequest 或 fetch API 來上傳壓縮文件。下面阿寶哥將以 axios 為例,來實現文件上傳的功能。

html 代碼

  1. <input type="file" id="uploadFile" webkitdirectory /> 
  2. <button id="submit" onclick="uploadFile()">上傳文件</button> 

js 代碼

  1. const uploadFileEle = document.querySelector("#uploadFile"); 
  2. const uploadOptions = { needZip = true }; 
  3.  
  4. const request = axios.create({ 
  5.   baseURL: "http://localhost:3000/"
  6.   timeout: 5000, 
  7. }); 
  8.  
  9. async function uploadFile({ needZip } = uploadOptions) { 
  10.   if (!uploadFileEle.files.length) return
  11.   let fileList = uploadFileEle.files; 
  12.   if (needZip) { // 對目錄進行ZIP壓縮 
  13.     let webkitRelativePath = fileList[0].webkitRelativePath; 
  14.     let zipFileName = webkitRelativePath.split("/")[0] + ".zip"
  15.     fileList = [await generateZipFile(zipFileName, fileList)]; 
  16.   } 
  17.   uploadFiles({ // 上傳文件列表 
  18.     url: "/upload/multiple"
  19.     files: fileList, 
  20.   }); 

在 uploadFile 函數中,如果有啟用目錄壓縮功能,我們就會調用 generateZipFile 函數生成 ZIP 文件,如果沒有的話,就會直接調用 uploadFiles 函數來上傳目錄中的所有文件,當然你也可以對文件列表進行過濾,比如限制文件類型或文件的大小等。

下面我們來看一下 uploadFiles 函數的具體實現:

  1. function uploadFiles({ url, files, fieldName = "file" }) { 
  2.   if (!url || !files.length) return
  3.   let formData = new FormData(); 
  4.   for (let i = 0; i < files.length; i++) { 
  5.     formData.append(fieldName, files[i], files[i].name); 
  6.   } 
  7.   return request.post(url, formData); 

在 uploadFiles 函數中,我們通過創建 FormData 對象來保存文件的信息,然后通過 request(axios 實例)來執行上傳操作。

二、服務器端

2.1 接收 ZIP 文件

在服務端要實現文件上傳功能也比較簡單,這里阿寶哥以 koa 為例來實現文件上傳的功能。如果你對 koa 還不了解的話,建議你先大致瀏覽一下 koa 的官方文檔。

  1. const path = require("path"); 
  2. const Koa = require("koa"); 
  3. const cors = require("@koa/cors"); 
  4. const multer = require("@koa/multer"); 
  5. const Router = require("@koa/router"); 
  6.  
  7. const app = new Koa(); 
  8. const router = new Router(); 
  9. const UPLOAD_DIR = path.join(__dirname, "/public/upload"); 
  10.  
  11. const storage = multer.diskStorage({ 
  12.   destination: async function (req, file, cb) { // 設置文件的存儲目錄 
  13.     cb(null, UPLOAD_DIR); 
  14.   }, 
  15.   filename: function (req, file, cb) { // 設置文件名 
  16.     cb(null, `${file.originalname}`); 
  17.   }, 
  18. }); 
  19.  
  20. const multerUpload = multer({ storage }); 
  21.  
  22. router.get("/", async (ctx) => { 
  23.   ctx.body = "壓縮文件目錄上傳示例(阿寶哥)"
  24. }); 
  25.  
  26. router.post( 
  27.   "/upload/multiple"
  28.   multerUpload.fields([ 
  29.     { 
  30.       name"file"
  31.     }, 
  32.   ]), 
  33.   async (ctx, next) => { 
  34.     ctx.body = { 
  35.       status: "success"
  36.       msg: "文件上傳成功"
  37.     }; 
  38.   } 
  39. ); 
  40.  
  41. // 注冊中間件 
  42. app.use(cors()); 
  43. app.use(router.routes()).use(router.allowedMethods()); 
  44.  
  45. app.listen(3000, () => { 
  46.   console.log("app starting at port 3000"); 
  47. }); 

在以上代碼中,我們通過 @koa/multer 這個中間件來處理文件上傳,對該中間件感興趣的小伙伴,可以自行閱讀官方文檔。接下來,我們來繼續討論另一個問題 —— 如何接收目錄并按照文件目錄結構進行存放?

2.2 接收文件目錄

前面我們已經知道,當 input[type="file"] 使用了 webkitdirectory 屬性之后,返回 File 對象的 webkitRelativePath 屬性就會存放當前文件相對于當前目錄的相對路徑:

因此當我們在服務端處理文件目錄上傳的功能時,我們就可以通過該屬性來創建對應的目錄結構,具體的處理邏輯如下所示:

  1. const fse = require("fs-extra"); 
  2.  
  3. const storage = multer.diskStorage({ 
  4.   destination: async function (req, file, cb) { 
  5.     // 把useAxios@demo.vue中的@替換為路徑分隔符 
  6.     let relativePath = file.originalname.replace(/@/g, path.sep);  
  7.     let index = relativePath.lastIndexOf(path.sep);  
  8.     let fileDir = path.join(UPLOAD_DIR, relativePath.substr(0, index)); // 生成文件路徑 
  9.     await fse.ensureDir(fileDir); // 確保當前目錄存在 
  10.     cb(null, fileDir); 
  11.   }, 
  12.   filename: function (req, file, cb) { 
  13.     let parts = file.originalname.split("@"); // 對路徑進行拆分 
  14.     cb(null, `${parts[parts.length - 1]}`); // 獲取文件名 
  15.   }, 
  16. }); 

為什么 originalname 文件原始名稱會包含 @ 符號呢?這樣因為使用 useAxios/demo.vue 這種路徑形式時,是不能獲取到完整的路徑名稱,只能獲取到文件名。為了解決這個問題,阿寶哥在上傳文件時,手動把文件相對路徑中的 / 符號替換為 @ 然后再進行上傳,對應的處理邏輯如下:

  1. function uploadFiles({ url, files, fieldName = "file" }) { 
  2.   if (!url || !files.length) return
  3.   let formData = new FormData(); 
  4.   for (let i = 0; i < files.length; i++) { 
  5.     formData.append(fieldName, files[i], files[i].webkitRelativePath.replace(/\//g, "@")); 
  6.   } 
  7.   return request.post(url, formData); 

好的,壓縮目錄上傳和目錄上傳已經介紹完了,感興趣的小伙伴可以動手試試看。由于完整的示例代碼內容比較多,阿寶哥就不放具體的代碼了。有需要的小伙伴,可以訪問以下地址瀏覽示例代碼。

https://gist.github.com/semlinker/af57349c16d203cc2ec845d4b5a6b445

注意:以上代碼僅供參考,請根據實際業務進行調整。

三、總結

本文阿寶哥介紹了如何利用 input[type="file"] 元素的 webkitdirectory 屬性來實現選擇目錄的功能,然后利用 JSZip 這個庫來實現目錄壓縮,最后通過 axios 來上傳目錄壓縮后的 ZIP 文件 。此外,阿寶哥還介紹了如何使用 koa 來實現接收目錄并按照文件目錄結構進行存放的功能。

四、參考資源

JSZip 官方文檔

MDN - webkitdirectory

JavaScript 如何在線解壓 ZIP 文件?

 

責任編輯:武曉燕 來源: 全棧修仙之路
相關推薦

2011-08-11 15:12:06

Xcode檢驗

2020-04-24 16:05:06

Javascript代碼前端

2012-02-09 09:10:44

Path通訊錄隱私

2020-03-06 10:05:59

前端Javascript代碼

2018-07-12 15:40:23

前端JavaScripthtml

2021-06-01 05:15:36

JavaScript 前端大文件并發上傳

2011-08-18 16:03:34

iPhone上傳圖片

2016-12-14 09:24:42

文件目錄壓縮

2020-10-20 11:12:11

Nodejs

2022-07-17 11:22:35

前端開發圖片裁切壓縮上傳

2017-07-04 15:10:20

移動端圖片旋轉壓縮

2011-05-25 16:44:01

JavaScriptCSS

2021-04-30 09:00:00

JavaScript開發上傳庫

2018-09-14 16:18:26

Linux壓縮文件應用程序

2021-12-26 23:34:00

微服務Istio壓縮

2009-06-09 21:54:26

傳遞參數JavaScript

2021-09-01 19:33:41

Source SentryDocker

2021-09-27 16:39:10

PythonGif壓縮

2016-11-23 18:52:04

根目錄日志代碼

2024-04-10 13:59:44

JavaScript內存
點贊
收藏

51CTO技術棧公眾號

av在线播放网站| 51妺嘿嘿午夜福利| 男女羞羞视频在线观看| 99热精品国产| 国产精品日韩精品| 午夜国产福利一区二区| 国产精品18hdxxxⅹ在线| 色哟哟一区二区| 91制片厂免费观看| 亚洲区小说区图片区| 捆绑调教一区二区三区| 国内自拍欧美激情| 日韩av毛片在线观看| 成人午夜三级| 欧美疯狂性受xxxxx喷水图片| 分分操这里只有精品| 91社区在线高清| 成年人网站91| 成人一区二区电影| 欧美日韩综合一区二区三区| 亚洲视频在线免费| 亚洲欧美在线一区二区| 国产精品91av| 色999韩欧美国产综合俺来也| 亚洲h在线观看| 在线观看免费91| 能在线看的av| 国产91精品精华液一区二区三区| 国产精品高清免费在线观看| 国产一卡二卡在线播放| 国产精品黑丝在线播放 | 国内精品中文字幕| 美国黄色片视频| 蜜桃国内精品久久久久软件9| 日韩欧美激情一区| 亚洲欧美视频二区| 快播电影网址老女人久久| 亚洲一区二区三区四区的| 亚洲三级一区| 国产福利在线| 久久婷婷国产综合精品青草| 国产精品一区二区三区不卡| 国产成人三级在线播放| 久久av中文字幕片| 国产精品自拍小视频| 免费黄色网址在线| 亚洲综合精品| 国产69久久精品成人看| 中文字幕一区二区三区手机版 | 国产香蕉视频在线| 国自产拍偷拍福利精品免费一| 日韩中文字幕精品| 国产综合精品久久久久成人av| 免费成人网www| 精品无人区太爽高潮在线播放| 国产原创剧情av| 成人午夜三级| 日韩国产激情在线| 中文字幕av网址| 啪啪亚洲精品| 在线国产精品视频| 国产视频不卡在线| 四虎成人av| 色偷偷偷综合中文字幕;dd| 中文字幕黄色网址| 欧美jizz| 久久av资源网站| 深夜福利影院在线观看| 海角社区69精品视频| 97免费视频在线| 亚洲国产成人无码av在线| 日韩精品国产欧美| 成人免费激情视频| 亚洲精品字幕在线| 91在线丨porny丨国产| 欧美激情第六页| p色视频免费在线观看| 亚洲欧美影音先锋| www.日本三级| 中文字幕 在线观看| 欧美曰成人黄网| 国产探花在线观看视频| 超碰精品在线| 国产午夜精品一区理论片飘花| 久久精品国产亚洲AV成人婷婷| 亚洲成人精选| 8x拔播拔播x8国产精品| 亚洲av人无码激艳猛片服务器| 蜜臀久久99精品久久久画质超高清| 成人性生交大片免费看视频直播| 亚洲成人黄色片| 91在线视频免费91| 亚洲三级一区| 激情国产在线| 欧美精三区欧美精三区| 天堂www中文在线资源| 国产99久久久国产精品成人免费| 色yeye香蕉凹凸一区二区av| 精品少妇久久久| 老色鬼久久亚洲一区二区| 成人黄色免费看| 熟妇高潮一区二区三区| 国产精品美女一区二区在线观看| 成年人看的毛片| 国产激情欧美| 日韩av在线免费观看| 91禁男男在线观看| 一道本一区二区| 国产欧美在线视频| 亚洲 小说区 图片区 都市| 国产精品高潮呻吟| 国产午夜福利精品| 国内揄拍国内精品久久| 精品美女视频在线观看免费软件| 天堂va蜜桃一区二区三区| 国产精品自拍偷拍| 香蕉久久国产av一区二区| 国产精品青草久久| 欧美综合在线视频| 国产精品免费看一区二区三区| 婷婷久久久久久| 国产精品久久国产精麻豆99网站 | 亚洲精品久久久久久久久久久久久久 | 亚洲一级片免费看| 99久久久久久| 国产成人亚洲综合无码| 97人人做人人爽香蕉精品| 精品盗摄一区二区三区| a一级免费视频| 91麻豆国产在线观看| 久久国产手机看片| 国产又爽又黄无码无遮挡在线观看| 亚洲制服一区| 久久久久久久久网站| 伊人影院中文字幕| 久久精品人人做人人综合| 国产黄色激情视频| 97久久超碰国产精品| 91精品久久香蕉国产线看观看| 欧美日韩国产中文字幕在线| 亚洲午夜激情网站| 在线观看av免费观看| 欧美手机在线| 日本亚洲欧美三级| 四虎在线视频| 婷婷激情综合网| 少妇伦子伦精品无吗| 婷婷综合激情| 国产免费一区二区三区在线能观看| 色屁屁草草影院ccyycom| 夜夜嗨av一区二区三区中文字幕| 精品国产乱码久久久久久1区二区| 清纯唯美亚洲综合一区| 国产精品美女网站| 91在线观看| 欧美丝袜丝交足nylons图片| 黄色片网站免费| 石原莉奈一区二区三区在线观看| 欧美一区二区视频17c| 综合久久2023| 亚洲福利免费| 92国产精品久久久久首页| 黄色av网站在线播放| 91精品福利在线一区二区三区 | 日本一级淫片演员| 欧美黄色a视频| 久久久国产视频| 国内精品偷拍视频| 亚洲国产美女搞黄色| 午夜精品久久一牛影视| 日韩av在线中文| 91九色精品| 91国产在线免费观看| 国产美女一区视频| 日韩高清a**址| 久久人人爽人人爽人人片av免费| 国产日韩成人精品| 污污的视频免费| 欧美成人69av| 精品午夜一区二区三区| 日韩在线短视频| 久久视频在线看| 欧美熟妇乱码在线一区| 黑人极品videos精品欧美裸| 精品无人区无码乱码毛片国产| 日韩成人av影视| 国产午夜精品视频一区二区三区| 卡通动漫国产精品| 国产精品美乳在线观看| 调教一区二区| 亚洲免费av片| 91亚洲精品国偷拍自产在线观看 | 欧美日韩大片一区二区三区| 精品女同一区二区三区在线观看| 欧美巨大黑人极品精男| 偷拍自拍在线| 欧美日韩中文字幕一区二区| 久草网在线观看| 国产亚洲va综合人人澡精品| 午夜影院免费版| 视频一区中文字幕国产| 日韩精品免费一区| 精品日韩欧美一区| 国产九色精品| 久久久国产精品网站| 久久久欧美精品| 欧美激情午夜| 亚洲美女视频网站| 免费毛片小视频| 欧美视频免费一区二区三区| 欧美午夜电影网| 免费在线观看av网址| 日本一区二区综合亚洲| 日韩综合第一页| 国产在线播放一区| 日本爱爱免费视频| 国产欧美一区二区色老头 | 丰满岳妇乱一区二区三区| 国产7777777| 99久久久无码国产精品| 亚洲成人激情小说| 蜜桃久久av一区| 日韩中文字幕在线视频观看| 亚洲激情久久| 亚洲欧洲日韩精品| 女人av一区| 精品国产乱码久久久久久郑州公司| 国产 日韩 欧美| 国产在线播放91| 日本黄色一区| 日韩美女主播视频| 丝袜诱惑一区二区| 久久久中精品2020中文| 手机在线免费av| 久久久精品久久| 乱人伦中文视频在线| 中文字幕精品久久| 韩国福利在线| 亚洲欧美制服第一页| 亚州av在线播放| 亚洲成avwww人| 亚洲精品97久久中文字幕| 欧美一区三区二区| 国产视频www| 欧美精品自拍偷拍| 97人妻精品一区二区三区| 欧美日韩一二区| 中文字幕av资源| 欧美日韩精品二区第二页| 91麻豆精品在线| 欧美影视一区二区三区| 久久久久久亚洲av无码专区| 色综合久久九月婷婷色综合| wwwwww国产| 色综合久久久久久久久| 免费av中文字幕| 欧美亚洲一区三区| 中文字幕视频免费观看| 欧美日韩国产免费一区二区 | 国产欧洲在线| 国产69久久精品成人| 亚洲深夜视频| 国产精品com| 欧美a一级片| 91最新在线免费观看| 亚洲欧美日本国产| 国产精品一区二区三区免费观看| 日本少妇一区二区三区| 久久精品国产一区二区三区免费看| 久久久久国产一区| 九色porny丨国产精品| 在线观看视频在线观看| 成人免费高清在线| 久久精品一区二区免费播放| 欧美国产精品中文字幕| 国产极品国产极品| 午夜精品一区二区三区三上悠亚| 成年人视频在线免费看| 欧美性一二三区| 国产叼嘿视频在线观看| 国产视频精品免费播放| 中文字幕在线播放| 欧美日本国产在线| 国产精品专区免费| 91久久久久久久| 久久国产精品色av免费看| 日韩精品一区二区三区外面| 亚洲天堂免费| 精品国产一二三四区| 蜜桃视频一区二区三区| 在线播放av网址| 国产欧美一区视频| 精品人妻在线播放| 欧美无乱码久久久免费午夜一区 | 无码人妻精品中文字幕| 一区二区三区四区在线播放| 毛片基地在线观看| 7777精品伊人久久久大香线蕉的 | 精品亚洲永久免费精品| 91官网在线| 国内精品中文字幕| 国产一区二区三区亚洲综合| 精品国产一区二区三区日日嗨| 成人女性视频| 欧美精品久久久久久久自慰 | 国产精国产精品| 一区二区在线视频观看| 日韩av一区二区三区美女毛片| 中文字幕日韩欧美精品高清在线| 精品人妻一区二区三区四区在线 | 日韩av免费大片| 精品这里只有精品| 国产一区二区三区精品欧美日韩一区二区三区| 日本一区二区在线观看视频| 中文字幕综合网| 黄色污污网站在线观看| 亚洲国产成人久久综合| 成人福利在线观看视频| 国产精品久久久久福利| 乱中年女人伦av一区二区| 欧美性受xxxx黑人猛交88| 秋霞影院一区二区| 国产一级视频在线播放| 91久久精品国产91性色tv| 亚洲乱色熟女一区二区三区| 国产一区二区三区在线看| av资源网在线播放| 亚洲专区中文字幕| 欧美岛国激情| 成人性做爰aaa片免费看不忠| 成人av手机在线观看| 可以直接看的黄色网址| 欧美日韩精品福利| 在线看免费av| 国产成人啪精品视频免费网| 欧美高清视频看片在线观看| 国产精品免费看久久久无码| 九九视频精品免费| 性生活免费观看视频| 噜噜噜在线观看播放视频| 久久韩剧网电视剧| 韩国女主播一区二区| 欧美不卡福利| 免费永久网站黄欧美| 女同性恋一区二区三区| 亚洲国产美国国产综合一区二区| www.精品久久| 欧美国产日韩精品| 日韩精品视频中文字幕| 免费看日b视频| 国产成人在线网站| 黄色一级片在线| 日韩精品中文字幕在线不卡尤物| av网站在线免费看推荐| 91精品天堂| 黑丝一区二区三区| 午夜不卡久久精品无码免费| 亚洲国产综合色| 日韩有码第一页| 欧美一级电影在线| 精品精品99| 亚洲男人天堂av在线| 亚洲人成精品久久久久久| 99国产精品久久久久久久成人| 欧美大片第1页| 嫩草国产精品入口| 欧美精品第三页| 国产精品国产三级国产三级人妇 | 黄色国产精品| 在线xxxxx| 色婷婷亚洲婷婷| 在线观看黄av| 99伊人久久| 99热精品在线| www色com| 91精品国产高清一区二区三区 | 无限资源日本好片| 自拍偷拍国产精品| 内射无码专区久久亚洲| 欧洲成人免费视频| 99久久婷婷这里只有精品| 能看毛片的网站| 色综合一区二区| 九色porny在线| 久久国产精品精品国产色婷婷| 日日骚欧美日韩| 黄色a级片在线观看| 亚洲国产成人精品一区二区| av免费在线一区| 91精品国产毛片武则天| 久久综合久久久久88| 国产精品欧美久久久久天天影视| 国产精品久久久乱弄| 少妇高潮一69aⅹ| 狠狠久久亚洲欧美专区| 求av网址在线观看| 亚洲午夜三级在线| jizz国产在线| 欧美激情国产日韩精品一区18| 西瓜成人精品人成网站|