欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

GitHub上一些實(shí)用的JavaScript的文件壓縮解壓縮庫(kù)推薦

 更新時(shí)間:2016年03月13日 11:15:31   作者:倪舒揚(yáng)  
這篇文章主要介紹了GitHub上一些實(shí)用的JavaScript的文件壓縮解壓縮庫(kù)推薦,推薦的這幾個(gè)都是支持zip格式的,需要的朋友可以參考下

項(xiàng)目里要用到archive和unarchive整個(gè)已存在的folder,在找解決方案的時(shí)候嘗試了一些當(dāng)前比較流行的library,主要有adm-zip, JSZip, archiver等。

一.Use adm-zip
adm-zip支持archive和unarchive一個(gè)或多個(gè)文件或者整個(gè)文件夾的功能,使用非常的簡(jiǎn)單方便。

  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. 同時(shí)實(shí)現(xiàn)了壓縮和解壓,而且只要提供路徑就可以對(duì)已存在的文件或文件夾進(jìn)行操作,實(shí)現(xiàn)了很多接口,使用方便簡(jiǎn)單。
2. 本身存在bug,有的時(shí)候解壓文件沒(méi)法還原到本來(lái)的文件。Hope慢慢這些bug會(huì)fix好。


二. UseJSZip
這個(gè)庫(kù)在使用的時(shí)候需要把文件一個(gè)個(gè)增加到zip對(duì)象中,而且需要把內(nèi)容也手動(dòng)添加,再使用寫(xiě)文件操作把內(nèi)存中的zip對(duì)象轉(zhuǎn)成物理存儲(chǔ)。所以如果是對(duì)于一整個(gè)文件夾來(lái)說(shuō),就很麻煩,需要遍歷文件夾。

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里面也有個(gè)folder方法,但它只是用來(lái)切換zip對(duì)象內(nèi)部的虛擬路徑,比如zip.folder("img").file('a.txt')就是在zip中添加一個(gè)img子目錄,在下面創(chuàng)建a.txt,效果等同于zip.file("img/a.txt")。這里還需要注意的是,文件的內(nèi)容都需要手動(dòng)添加,如果僅僅是zip.file("a.txt");只是在zip對(duì)象中創(chuàng)建了內(nèi)容為空的txt文件,而且它只是存在于內(nèi)存中,需要寫(xiě)文件操作后才會(huì)真正存到磁盤(pán)。

Pros and cons:
1.對(duì)于一些實(shí)時(shí)接受到的數(shù)據(jù)轉(zhuǎn)成zip的比較適用。 2.對(duì)于已存在的文件夾操作不便,需要一個(gè)個(gè)把內(nèi)容添加到zip對(duì)象,再轉(zhuǎn)成文件。
3.很多編碼需要注意。
4.只有壓縮功能。


三. Use archiver and unzip
這個(gè)組合是最后我使用的,比較靠譜,使用也比較簡(jiǎn)單,其中archiver很強(qiáng)大,支持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. 均只提供壓縮或者解壓,沒(méi)有兩個(gè)功能都實(shí)現(xiàn)的。(所以adm-zip其實(shí)很好用,但bug是硬傷啊...)

這些只是我昨天找的一些庫(kù),歡迎推薦其他庫(kù)么么噠

相關(guān)文章

  • vscode+gulp輕松開(kāi)發(fā)小程序的完整步驟

    vscode+gulp輕松開(kāi)發(fā)小程序的完整步驟

    這篇文章主要給大家介紹了關(guān)于vscode+gulp輕松開(kāi)發(fā)小程序的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • js中常見(jiàn)的6種繼承方式總結(jié)

    js中常見(jiàn)的6種繼承方式總結(jié)

    js中的繼承與其說(shuō)是對(duì)象的繼承,但更像是讓函數(shù)的功能和用法的復(fù)用,下面這篇文章主要給大家介紹了關(guān)于js中常見(jiàn)的6種繼承方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • echarts修改橫坐標(biāo)顏色簡(jiǎn)單代碼示例

    echarts修改橫坐標(biāo)顏色簡(jiǎn)單代碼示例

    這篇文章主要給大家介紹了關(guān)于echarts修改橫坐標(biāo)顏色的相關(guān)資料,在項(xiàng)?中常常會(huì)?到echarts的實(shí)例,根據(jù)不同的需求字體顏?需要變化,需要的朋友可以參考下
    2023-07-07
  • JavaScript遞歸操作實(shí)例淺析

    JavaScript遞歸操作實(shí)例淺析

    這篇文章主要介紹了JavaScript遞歸操作,由一個(gè)階乘問(wèn)題開(kāi)始分析了遞歸操作的原理、實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2016-10-10
  • 簡(jiǎn)單的漸變輪播插件

    簡(jiǎn)單的漸變輪播插件

    本文主要介紹了簡(jiǎn)單的漸變輪播插件,具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • 跨域資源共享 CORS 詳解

    跨域資源共享 CORS 詳解

    所有瀏覽器都支持該功能IE瀏覽器不能低于IE10.整個(gè)CORS通信過(guò)程都是瀏覽器自動(dòng)完成不需要用戶(hù)參與。對(duì)于開(kāi)發(fā)者來(lái)說(shuō)CORS通信與同源的AJAX通信沒(méi)有差別代碼完全一樣瀏覽器一旦發(fā)現(xiàn)AJAX請(qǐng)求跨源就會(huì)自動(dòng)添加一些附加的頭信息有時(shí)還會(huì)多出一次附加的請(qǐng)求,但用戶(hù)不會(huì)有感覺(jué)。
    2016-04-04
  • JS script腳本中async和defer區(qū)別詳解

    JS script腳本中async和defer區(qū)別詳解

    這篇文章主要介紹了JS script腳本中async和defer區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • js實(shí)現(xiàn)的頁(yè)面矩陣圖形變換特效

    js實(shí)現(xiàn)的頁(yè)面矩陣圖形變換特效

    這篇文章主要介紹了js實(shí)現(xiàn)的頁(yè)面矩陣圖形變換特效,涉及JavaScript利用數(shù)組與字符串的數(shù)學(xué)運(yùn)算操作頁(yè)面節(jié)點(diǎn)樣式變換的相關(guān)技巧,需要的朋友可以參考下
    2016-01-01
  • 老生常談JavaScript獲取CSS樣式的方法(兼容各瀏覽器)

    老生常談JavaScript獲取CSS樣式的方法(兼容各瀏覽器)

    大家都知道CSS樣式有三種類(lèi)型:行內(nèi)樣式、內(nèi)部樣式和外部樣式,這篇文章主要介紹了javaScript獲取CSS樣式的方法(兼容各瀏覽器),需要的朋友可以參考下
    2018-09-09
  • layer彈出層父子頁(yè)面事件相互調(diào)用方法

    layer彈出層父子頁(yè)面事件相互調(diào)用方法

    今天小編就為大家分享一篇layer彈出層父子頁(yè)面事件相互調(diào)用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08

最新評(píng)論