电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

js實現多張圖片打包成zip

瀏覽:92日期:2024-03-24 09:36:24
目錄1、引入文件2、html頁面3、主要代碼4、優化圖片轉base64的流程,提高zip的打包速度5、再優化,通過axios把圖片轉成base641、引入文件

<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>2、html頁面

<button onclick='packageImages()'>下載zip</button><span id='status'></span>3、主要代碼

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.jssaveAs(content, ’images.zip’)$(’#status’).text(’處理完成。。。。?!? })} }, function (err) {console.log(err) //打印異常信息 }) }}//傳入圖片路徑,返回base64function getBase64(img) { function getBase64Image(img, width, height) {//width、height調用時傳入具體像素值,控制大小 ,不傳則默認圖像大小var canvas = document.createElement(’canvas’)canvas.width = width ? width : img.widthcanvas.height = height ? height : img.heightvar 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’] }}4、優化圖片轉base64的流程,提高zip的打包速度

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);//如果是轉文字,第二個參數可以使用編碼})}5、再優化,通過axios把圖片轉成base64

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的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 合肥办公室装修 - 合肥工装公司 - 天思装饰 | 农产品溯源系统_农产品质量安全追溯系统_溯源系统 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 广州食堂承包_广州团餐配送_广州堂食餐饮服务公司 - 旺记餐饮 | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | 过跨车_过跨电瓶车_过跨转运车_横移电动平车_厂区转运车_无轨转运车 | 海鲜池-专注海鲜鱼缸、移动海鲜缸、饭店鱼缸设计定做-日晟水族厂家 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | 国际金融网_每日财经新资讯网 | 冷却塔厂家_冷却塔维修_冷却塔改造_凉水塔配件填料公司- 广东康明节能空调有限公司 | 美的商用净水器_美的直饮机_一级代理经销商_Midea租赁价格-厂家反渗透滤芯-直饮水批发品牌售后 | 生物颗粒燃烧机-生物质燃烧机-热风炉-生物颗粒蒸汽发生器-丽水市久凯能源设备有限公司 | 扬尘监测_扬尘监测系统_带证扬尘监测设备 - 郑州港迪科技有限公司 | 电位器_轻触开关_USB连接器_广东精密龙电子科技有限公司 | 三氯异氰尿酸-二氯-三氯-二氯异氰尿酸钠-优氯净-强氯精-消毒片-济南中北_优氯净厂家 | 上海租车公司_上海包车_奔驰租赁_上海商务租车_上海谐焕租车 | 丹尼克尔拧紧枪_自动送钉机_智能电批_柔性振动盘_螺丝供料器品牌 | 阻燃剂-氢氧化镁-氢氧化铝-沥青阻燃剂-合肥皖燃新材料 | 紫外线老化试验箱_uv紫外线老化试验箱价格|型号|厂家-正航仪器设备 | 流水线电子称-钰恒-上下限报警电子秤-上海宿衡实业有限公司 | 水性漆|墙面漆|木器家具漆|水漆涂料_晨阳水漆官网 | 中高频感应加热设备|高频淬火设备|超音频感应加热电源|不锈钢管光亮退火机|真空管烤消设备 - 郑州蓝硕工业炉设备有限公司 | 电动不锈钢套筒阀-球面偏置气动钟阀-三通换向阀止回阀-永嘉鸿宇阀门有限公司 | 睿婕轻钢别墅_钢结构别墅_厂家设计施工报价 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 电线电缆厂家|沈阳电缆厂|电线厂|沈阳英联塑力线缆有限公司 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | 「钾冰晶石」氟铝酸钾_冰晶石_氟铝酸钠「价格用途」-亚铝氟化物厂家 | 长沙中央空调维修,中央空调清洗维保,空气能热水工程,价格,公司就找维小保-湖南维小保环保科技有限公司 | 代理记账_免费注册公司_营业执照代办_资质代办-【乐财汇】 | RS系列电阻器,RK_RJ启动调整电阻器,RQ_RZ电阻器-上海永上电器有限公司 | 电子天平-华志电子天平厂家| 青海电动密集架_智能密集架_密集架价格-盛隆柜业青海档案密集架厂家 | 桨叶搅拌机_螺旋挤压/方盒旋切造粒机厂家-无锡市鸿诚输送机械有限公司 | ZHZ8耐压测试仪-上海胜绪电气有限公司 | RS系列电阻器,RK_RJ启动调整电阻器,RQ_RZ电阻器-上海永上电器有限公司 | 嘉兴泰东园林景观工程有限公司_花箱护栏 | 硅胶管挤出机厂家_硅胶挤出机生产线_硅胶条挤出机_臣泽智能装备 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | 灌装封尾机_胶水灌装机_软管灌装封尾机_无锡和博自动化机械制造有限公司 | 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 广州物流公司_广州货运公司_广州回程车运输 - 万信物流 |