一、使用工具
压缩工具:jszip
nodejs引用
var fs = require('fs');
var JSZip = require('jszip');
二、资源打包下载
此处代码根据所开发项目特定抽取的,可根据个人实际情况进行修改。
1.伪造数据
①伪造json数据
var jsonArray = [ { name:"data1",//导出json文件的名字,不需要后缀 data:{a:1,b:1}//对应json文件的json字符串 }, { name:"data2", data:{} } ];此伪数据可导出两个json文件②伪造文件数据
此伪数据可导出一个图片var fileArray = new Array(); fileArray.push({ name:"image1.jpg",//文件名称 path:"D:/image1.jpg",//文件路径 });
2.导出方法
//导出压缩包 function exportZip(res, zipName, jsonArray,fileArray) { var zip = new JSZip(); //json文件打包 for (var i = 0; i < jsonArray.length; i++) { zip.file(jsonArray[i].name+".json", JSON.stringify(jsonArray[i].data)); } //文件打包 for (var i = 0; i < fileArray.length; i++) { var fileObj = fileArray[i]; zip.file(fileObj.name,fs.readFileSync(fileObj.path)); } var data = zip.generate({base64: false, compression: 'DEFLATE'}); //importpath:压缩文件生成位置,此处不修改了,可自己修改 fs.writeFile(importpath + zipName+'.zip', data, 'binary', function () { res.setHeader('Content-Type', 'application/vnd.openxmlformats'); res.setHeader("Content-Disposition", "attachment; filename=" + zipName + ".zip"); res.end(fs.readFileSync(importpath + zipName+".zip"), 'binary'); fs.unlinkSync(importpath + zipName+".zip"); console.log("导出" + zipName+".zip" + "成功"); }); }
三、前台调用window.open(url);//url = 后台请求接口
就这样,做个简单记录,留个印象。