GitHub上一些實用的JavaScript的文件壓縮解壓縮庫推薦
項目里要用到archive和unarchive整個已存在的folder,在找解決方案的時候嘗試了一些當前比較流行的library,主要有adm-zip, JSZip, archiver等。
一.Use adm-zip
adm-zip支持archive和unarchive一個或多個文件或者整個文件夾的功能,使用非常的簡單方便。
var adm_zip = require('adm-zip');
//creating archives
var zip = new adm_zip();
zip.addLocalFolder('archiver');
zip.writeZip('adm/adm-archive.zip');
//extracting archives
var unzip = new adm_zip('adm/adm-archive.zip');
unzip.extractAllTo("adm/adm-unarchive/", /*overwrite*/true);
Pros and cons:
1. 同時實現(xiàn)了壓縮和解壓,而且只要提供路徑就可以對已存在的文件或文件夾進行操作,實現(xiàn)了很多接口,使用方便簡單。
2. 本身存在bug,有的時候解壓文件沒法還原到本來的文件。Hope慢慢這些bug會fix好。
二. UseJSZip
這個庫在使用的時候需要把文件一個個增加到zip對象中,而且需要把內(nèi)容也手動添加,再使用寫文件操作把內(nèi)存中的zip對象轉(zhuǎn)成物理存儲。所以如果是對于一整個文件夾來說,就很麻煩,需要遍歷文件夾。
var JSZip = require("jszip");
var fs = require("fs");
var zip = new JSZip();
var file_content = fs.readFileSync('archive/a.txt');
zip.file("a.txt",file_content);
var data = fs.readFileSync("archive/img/pic.jpeg");
zip.file("img/pic.jpeg", data, {base64: true});
var zipfolder = zip.generate({type:"nodebuffer"});
fs.writeFile("jszip.zip", zipfolder, function(err) {
if (err) throw err;
});
JSZip里面也有個folder方法,但它只是用來切換zip對象內(nèi)部的虛擬路徑,比如zip.folder("img").file('a.txt')就是在zip中添加一個img子目錄,在下面創(chuàng)建a.txt,效果等同于zip.file("img/a.txt")。這里還需要注意的是,文件的內(nèi)容都需要手動添加,如果僅僅是zip.file("a.txt");只是在zip對象中創(chuàng)建了內(nèi)容為空的txt文件,而且它只是存在于內(nèi)存中,需要寫文件操作后才會真正存到磁盤。
Pros and cons:
1.對于一些實時接受到的數(shù)據(jù)轉(zhuǎn)成zip的比較適用。 2.對于已存在的文件夾操作不便,需要一個個把內(nèi)容添加到zip對象,再轉(zhuǎn)成文件。
3.很多編碼需要注意。
4.只有壓縮功能。
三. Use archiver and unzip
這個組合是最后我使用的,比較靠譜,使用也比較簡單,其中archiver很強大,支持zip格式tar格式,只需要提供路徑就可以壓縮已存在的文件夾。 壓縮:
var fs = require('fs');
var archiver = require('archiver');
var output = fs.createWriteStream('archiver-unzip.zip');
var archive = archiver('zip');
archive.on('error', function(err){
throw err;
});
archive.pipe(output);
archive.bulk([
{ src: ['archiver/**']}
]);
archive.finalize();
解壓:
var fs = require("fs");
var unzip = require("unzip");
fs.createReadStream('archiver-unzip.zip').pipe(unzip.Extract({ path: 'unarchive' }));
Pros and cons:
1. 久經(jīng)試用,bug較少。
2.使用方便,不需要遍歷文件夾。
3. 均只提供壓縮或者解壓,沒有兩個功能都實現(xiàn)的。(所以adm-zip其實很好用,但bug是硬傷啊...)
這些只是我昨天找的一些庫,歡迎推薦其他庫么么噠
相關(guān)文章
element-ui的回調(diào)函數(shù)Events的用法詳解
這篇文章主要介紹了element-ui的回調(diào)函數(shù)Events的用法,本文通過實例代碼給大家介紹了change回調(diào)函數(shù)的使用方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10
原生JS實現(xiàn)仿淘寶網(wǎng)左側(cè)商品分類菜單效果代碼
這篇文章主要介紹了原生JS實現(xiàn)仿淘寶網(wǎng)左側(cè)商品分類菜單效果代碼,可實現(xiàn)簡單的鼠標滑過tab切換的功能,非常簡單實用,需要的朋友可以參考下2015-09-09
webpack打包后index.html引用文件地址問題小結(jié)
在前端開發(fā)中,src 屬性指定的相對路徑是相對于當前 HTML 文件的路徑,而不是相對于網(wǎng)站的根目錄,這篇文章主要介紹了webpack打包后index.html引用文件地址問題,需要的朋友可以參考下2024-05-05
基于aotu.js實現(xiàn)微信自動添加通訊錄中的聯(lián)系人功能
這篇文章主要介紹了利用aotu.js實現(xiàn)微信自動添加通訊錄中的聯(lián)系人,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05
easyui combogrid實現(xiàn)本地模糊搜索過濾多列
本篇文章主要介紹了easyui combogrid實現(xiàn)本地模糊搜索過濾多列,非常具有實用價值,需要的朋友可以參考下2017-05-05

