java上传图片压缩包(js实现多张图片打包成zip)
类别:编程学习 浏览量:2814
时间:2022-01-28 01:28:52 java上传图片压缩包
js实现多张图片打包成zip目录
- 1、引入文件
- 2、html页面
- 3、主要代码
- 4、优化图片转base64的流程,提高zip的打包速度
- 5、再优化,通过axios把图片转成base64
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/jszip/3.6.0/jszip.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/FileSaver.js/2.0.5/FileSaver.min.js"></script>
<button onclick="packageImages()">下载zip</button><span id="status"></span>
function packageImages() { $('#status').text('处理中。。。。。') var imgsSrc = [] // https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg // https://dss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=2151136234,3513236673&fm=26&gp=0.jpg for (var i = 0; i < 1; i++) { imgsSrc.push('https://img.alicdn.com/bao/uploaded/i1/446338500/O1CN01npzdZ52Cf3A4cx8JG_!!0-item_pic.jpg_240x240.jpg') } var imgBase64 = [] //base64图片 var imageSuffix = [] //图片后缀 var zip = new JSZip() zip.file('readme.txt', '案件详情资料\n') var img = zip.folder('images') for (var i = 0; i < imgsSrc.length; i++) { var suffix = imgsSrc[i].substring(imgsSrc[i].lastIndexOf('.')) imageSuffix.push(suffix) getBase64(imgsSrc[i]).then( function (base64) { console.log(base64) imgBase64.push(base64.replace(/^data:image\/(png|jpg|jpeg);base64,/, "")) // 当所有图片转成base64执行图片压缩 if (imgsSrc.length == imgBase64.length) { for (var i = 0; i < imgsSrc.length; i++) { // 文件名 数据 img.file(i + imageSuffix[i], imgBase64[i], { base64: true, }) } zip.generateAsync({ type: 'blob' }).then(function (content) { console.log(1) // see FileSaver.js saveAs(content, 'images.zip') $('#status').text('处理完成。。。。。') }) } }, function (err) { console.log(err) //打印异常信息 } ) } } //传入图片路径,返回base64 function getBase64(img) { function getBase64Image(img, width, height) { //width、height调用时传入具体像素值,控制大小 ,不传则默认图像大小 var canvas = document.createElement('canvas') canvas.width = width ? width : img.width canvas.height = height ? height : img.height var ctx = canvas.getContext('2d') ctx.drawImage(img, 0, 0, canvas.width, canvas.height) var dataURL = canvas.toDataURL() return dataURL } var image = new Image() image.crossOrigin = 'Anonymous' image.src = img var deferred = $.Deferred() if (img) { image.onload = function () { deferred.resolve(getBase64Image(image)) //将base64传给done上传处理 } return deferred.promise() //问题要让onload完成后再return sessionStorage['imgTest'] } }
function packageImages() { $('#status').text('处理中。。。。。') var imgsSrc = [] // https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg // https://dss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=2151136234,3513236673&fm=26&gp=0.jpg for (var i = 0; i < 1; i++) { imgsSrc.push('https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg') } var imgBase64 = [] //base64图片 var imageSuffix = [] //图片后缀 var zip = new JSZip() zip.file('readme.txt', '案件详情资料\n') var img = zip.folder('images') for (var i = 0; i < imgsSrc.length; i++) { var suffix = imgsSrc[i].substring(imgsSrc[i].lastIndexOf('.')) imageSuffix.push(suffix) getBase64(imgsSrc[i], function (base64) { imgBase64.push(base64.replace(/^data:image\/(png|jpg|jpeg);base64,/, "")) if (imgsSrc.length == imgBase64.length) { for (var i = 0; i < imgsSrc.length; i++) { // 文件名 数据 img.file(i + imageSuffix[i], imgBase64[i], { base64: true, }) } zip.generateAsync({ type: 'blob' }).then(function (content) { console.log(1) // see FileSaver.js saveAs(content, 'images.zip') $('#status').text('处理完成。。。。。') }) } }) } } function getBase64(img, callback) { fetch(img).then( res => res.blob()) .then(res => { let fr = new FileReader();//https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader fr.onload = function (e) { callback(e.target.result) }; fr.onerror = function () { console.log('读取错误!') }; fr.readAsDataURL(res);//如果是转文字,第二个参数可以使用编码 }) }
function packageImages() { $('#status').text('处理中。。。。。') var imgsSrc = [] // https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg // https://dss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=2151136234,3513236673&fm=26&gp=0.jpg for (var i = 0; i < 100; i++) { imgsSrc.push('https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg') } handleBatchDownload(imgsSrc) } getFile = (url) => { return new Promise((resolve, reject) => { axios({ method: 'get', url, responseType: 'arraybuffer' }).then(data => { resolve(data.data) }).catch(error => { reject(error.toString()) }) }) }; // 批量下载 handleBatchDownload = async (selectImgList) => { const data = selectImgList; const zip = new JSZip() const promises = [] await data.forEach((item, idx) => { // console.log(item, idx) const promise = this.getFile(item).then(async (data) => { // 下载文件, 并存成ArrayBuffer对象 const arr_name = item.split("/"); let file_name = arr_name[arr_name.length - 1] // 获取文件名 // if (file_name.indexOf('.png') == -1) { // file_name = file_name + '.png' // } await zip.file(idx + '.png', data, { binary: true }) // 逐个添加文件 }) promises.push(promise) }) Promise.all(promises).then(() => { zip.generateAsync({ type: "blob" }).then(content => { // 生成二进制流 saveAs(content, "photo.zip") // 利用file-saver保存文件 $('#status').text('处理完成。。。。。') }) }) };
以上就是js实现多张图片打包成zip的详细内容,更多关于js 图片打包成zip的资料请关注开心学习网其它相关文章!
您可能感兴趣
- js基础入门运算符(js 可选链操作符的使用)
- js实时获取页面宽度(JavaScript获取网页的宽高及如何兼容详解)
- nodejs登录案例(利用Node.js创建一个密码生成器的全步骤)
- nodejs游戏服务端框架(如何写Node.JS版本小游戏)
- 前端表单验证(AmazeUI的JS表单验证框架实战示例分享)
- react组件分析(react-diagram 序列化Json解读案例分析)
- ASP.NET中XML和JSON互转
- nodejs子进程调试(Node.js实现断点续传)
- 微信发送镭射效果代码(JS实现微信"炸屎"大作战功能)
- python json转换字符串(python3 json数据格式的转换dumps/loads的使用、dict to str/str to dict、json字符串/字典)
- js中encodeURIComponent与C#中HttpUtility.UrlEncode
- js中Document
- vuejs图片缩放裁切(vue+js点击箭头实现图片切换)
- vuejs filter过滤器的使用(Vue过滤器filter实现及应用场景详解)
- js原型链的理解(浅谈JS的原型和原型链)
- js的showModalDialog的用法
- 哪版孙悟空最萌 黄渤躺萌了(哪版孙悟空最萌)
- 融入小人物的喜怒哀乐,黄渤饰演的角色为什么让人观看时欲罢不能(融入小人物的喜怒哀乐)
- 《极限挑战》深访都市夜归人,夜间打工者体验,黄磊录完憔悴了(极限挑战深访都市夜归人)
- Google 推出了一个游戏生成器,让不会编程的你也能自己设计游戏(推出了一个游戏生成器)
- 二胎家庭老大爱闹情绪,用这招很有效(二胎家庭老大爱闹情绪)
- 一个30岁男人外遇失败的全过程(一个30岁男人外遇失败的全过程)
热门推荐
- MVC中BeginForm
- dedecms怎样开启wap(dedecms织梦登录后台菜单栏无法显示解决方法)
- dedecms标签怎么用(dedecms列表页上一页下一页翻页单独调用的方法)
- php如何获取当前日期(php实现获取近几日、月时间示例)
- html5+canvas动画(解析html5 canvas实现背景鼠标连线动态效果代码)
- sql server证书配置(SQL Server Alwayson创建代理作业的注意事项详解)
- mysql中json的支持(MySQL中json字段的操作方法)
- 普通人如何申请阿里云账号(怎么注册阿里云账号 阿里云帐号怎么申请)
- pandas导入及数据结构用法(pandas数据集的端到端处理)
- 使用TLS加密通讯远程连接Docker的示例详解(使用TLS加密通讯远程连接Docker的示例详解)