日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue將文件/圖片批量打包下載zip的教程

瀏覽:193日期:2022-11-15 15:36:31

vue將文件/圖片批量打包下載

各種格式都可以,只要url能夠打開(kāi)或者下載文件即可.

1.通過(guò)文件的url,使用js的XMLHttpRequest獲取blob

2.將blob壓縮為zip

由于異步并行加載文件,速度還是蠻快的,我141個(gè)4M多的圖片,1分左右加載完成,49個(gè)4M的圖片4秒

vue將文件/圖片批量打包下載zip的教程

vue將文件/圖片批量打包下載zip的教程

添加依賴(lài)

//npm install jszip

//npm install file-saver

在頁(yè)面的script中引入依賴(lài)

import JSZip from ’jszip’

import FileSaver from ’file-saver’

代碼

/**文件打包 * arrImages:文件list:[{fileUrl:文件url,renameFileName:文件名}] * filename 壓縮包名 * */ filesToRar(arrImages, filename) { let _this = this; let zip = new JSZip(); let cache = {}; let promises = []; _this.title = ’正在加載壓縮文件’; for (let item of arrImages) { const promise= _this.getImgArrayBuffer(item.fileUrl).then(data => { // 下載文件, 并存成ArrayBuffer對(duì)象(blob) zip.file(item.renameFileName, data, { binary: true }); // 逐個(gè)添加文件 cache[item.renameFileName] = data; }); promises.push(promise); } Promise.all(promises).then(() => { zip.generateAsync({ type: 'blob' }).then(content => { _this.title = ’正在壓縮’; // 生成二進(jìn)制流 FileSaver.saveAs(content, filename); // 利用file-saver保存文件 自定義文件名 _this.title = ’壓縮完成’; }); }).catch(res=>{ _this.$message.error(’文件壓縮失敗’); }); }, //獲取文件blob getImgArrayBuffer(url){ let _this=this; return new Promise((resolve, reject) => { //通過(guò)請(qǐng)求獲取文件blob格式 let xmlhttp = new XMLHttpRequest(); xmlhttp.open('GET', url, true); xmlhttp.responseType = 'blob'; xmlhttp.onload = function () { if (this.status == 200) { resolve(this.response); }else{ reject(this.status); } } xmlhttp.send(); }); },

補(bǔ)充知識(shí):vue 生成二維碼并且批量打包下載代碼

我就廢話(huà)不多說(shuō)了,大家還是直接看代碼吧~

<template><div><div v-show='codeId' ref='QrcodePage' style='z-index:-1111;position:absolute;left:-99999;width: 450px;height: 475px;background-size: cover;'><div v-if='codeId'><QrcodeVue :logoSrc='imageUrl' :key='random' :callback='texte' :text='codeValue' :logoScale='50' :size='750'></QrcodeVue><p style='text-align: center; font-size: 1.5625rem;'>{{ codeNumber }}</p></div></div></div></template><script>let loadingInstance = ’’;import QrcodeVue from ’vue-qr’;import html2canvas from ’html2canvas’;import JSZip from ’jszip’;import FileSaver from ’file-saver’;export default {name: ’qrcode’,components: {QrcodeVue},data() {return {random: ’1’,codeId: ’’,qrcodeUrl: ’’,imageUrl: ’’,// imageUrl: ’https://shop.mmdddd.com/workShopWeb/static/img/72.png’,//logoqrContentImage: ’’,codeValue: ’’,initCodeVal: ’http://xcx.nmte.net/tips/index.html’,codeNumber: ’’,arr: [],qrcodeArr: [],index: 0};},watch: {index(newName, oldName){if(newName != oldName && newName <= this.arr.length-1){setTimeout(_ => {this.setarr(this.arr);}, 0);}else {this.$nextTick(_ => {loadingInstance.close();});}}},created() {},mounted() {},methods: {texte(url,qid) {setTimeout(_ => {this.createImgs();}, 100);},setarr(arr) {this.arr = arr;if(this.index > this.arr.length -1) {this.index = 0;}let index=this.index||0;loadingInstance = this.$Loading.service({lock: true, text: ’二維碼碼批量下載中,請(qǐng)稍后...’, spinner: ’el-icon-loading’, background: ’rgba(0, 0, 0, 0.7)’});this.codeNumber = this.arr[index].codeNumber; this.arr[index].codeId ? (this.codeId = this.arr[index].codeId) : this.$Message.warn(’獲取信息失敗,請(qǐng)刷新重試’);this.codeValue = this.initCodeVal + ’?codeId=’ + this.arr[index].codeId + ’&codeNumber=’ + this.arr[index].codeNumber;this.random = Math.random(); },createImgs() {var that = this;if(that.index <= that.arr.length -1 && that.codeId){let shareContent = that.$refs.QrcodePage, width = shareContent.offsetWidth, height = shareContent.offsetHeight,canvas = document.createElement(’canvas’), scale = 1; canvas.width = width * scale; canvas.height = height * scale; canvas.style.width = (shareContent.clientWidth * scale) / 100 + ’rem’;canvas.style.height = (shareContent.clientHeight * scale) / 100 + ’rem’;canvas.getContext(’2d’).scale(scale, scale); let opts = {scale: scale, canvas: canvas,logging: false,width: width, height: height,useCORS: true};html2canvas(shareContent, opts).then(function(canvas) {const qrContentImage = canvas.toDataURL(’image/jpeg’, 1.0);if(that.index <= that.arr.length -1 && that.codeId){that.qrcodeArr.push({url: qrContentImage,name: that.arr[that.index].codeNumber});}if(that.codeId){that.index ++;}if(that.qrcodeArr.length == that.arr.length){that.packageImages();that.codeId = null;}}).catch(function(reason) {console.log(reason);});}},packageImages() {let that = this;const zip = new JSZip();const cache = {};setTimeout(_ => {let arr = that.qrcodeArr;arr.forEach((item,index)=>{let fileName = item.name;zip.file(fileName + ’.png’,item.url.substring(22),{base64:true})cache[fileName] = item.url})zip.generateAsync({type:'blob'}).then(content => { FileSaver.saveAs(content, '二維碼.zip') })},0)}}};</script><style lang='less' scoped='scoped'>#qrCode {width: 375px;height: 375px;position: absolute;top: 52%;left: 50%;transform: translate(-50%, -50%);img {display: block;width: 100%;height: 100%;}}</style>

調(diào)用setarr傳數(shù)組

以上這篇vue將文件/圖片批量打包下載zip的教程就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产一区二区久久久久| 日韩精品免费一区二区夜夜嗨 | 深夜福利亚洲| 激情久久中文字幕| 福利片在线一区二区| 国产三级一区| 国产伦乱精品| 久久久国产精品网站| 九九99久久精品在免费线bt| 久久99偷拍| 欧美国产视频| 精品国产乱码| 一本大道色婷婷在线| 欧美日韩精品一区二区视频| 99久久久国产精品美女| 成人羞羞视频播放网站| 久久精品中文| 免费在线观看一区二区三区| 亚洲视频国产精品| 性一交一乱一区二区洋洋av| 亚洲作爱视频| 国产免费av国片精品草莓男男| 日本国产一区| 国产成人黄色| 亚洲视频综合| 亚洲69av| 成人台湾亚洲精品一区二区| 91精品国产乱码久久久久久久 | 精品久久国产一区| 激情综合网五月| 久久不射中文字幕| 国产探花一区在线观看| 欧美天堂视频| 亚洲二区三区不卡| 水蜜桃久久夜色精品一区的特点| 日韩视频一区| 国产精品男女| 国户精品久久久久久久久久久不卡 | 国产专区精品| 日韩天堂av| 麻豆精品视频在线观看视频| 极品日韩av| 男人操女人的视频在线观看欧美| 麻豆久久一区二区| 日韩视频一区二区三区在线播放免费观看 | 亚洲毛片网站| 99久久夜色精品国产亚洲1000部| 亚洲欧美网站在线观看| 精品一区二区三区的国产在线观看| 久久中文字幕av| 国产激情一区| 亚洲精品国产精品粉嫩| 99免费精品| 在线手机中文字幕| 国产精品毛片| 久久国产中文字幕| 在线看片福利| 黄色精品视频| 精品久久一区| 久久精品国产一区二区| 国产精品色在线网站| 国产精品一在线观看| 日本不卡一二三区黄网| 在线国产日韩| 日韩av在线免费观看不卡| 在线亚洲自拍| 久久久久.com| 久久男人av| 久久不见久久见国语| 少妇精品久久久一区二区| 91成人精品| 99精品国产一区二区三区| 三上悠亚国产精品一区二区三区| 国产剧情一区| 美女91精品| 日韩精彩视频在线观看| 国产亚洲一区在线| 国产精品毛片| 99在线观看免费视频精品观看| av资源中文在线天堂| 国产精品久久久亚洲一区| 欧美亚洲免费| 国产精品乱战久久久| 91偷拍一区二区三区精品| 美女精品视频在线| 国产亚洲精品精品国产亚洲综合| 中文在线日韩| 欧美一级网址| 欧美偷窥清纯综合图区| 日本亚洲视频| 青青国产精品| 日韩av三区| av资源亚洲| 伊人精品视频| 日韩精品亚洲专区| 欧美极品中文字幕| 狠狠躁少妇一区二区三区| 日韩欧美二区| aa国产精品| 国产精品字幕| 日韩av二区在线播放| 美女久久久久久 | 一区二区电影| 日韩av午夜在线观看| 天海翼精品一区二区三区| 亚洲人成毛片在线播放女女| 国产乱码精品一区二区三区亚洲人| 欧美精品第一区| 国产精品宾馆| 欧美日韩水蜜桃| 少妇精品久久久一区二区| 欧美精品不卡| 999久久久精品国产| 中文字幕日韩欧美精品高清在线| 国产精品一卡| 亚洲播播91| 亚洲精品在线a| 国产亚洲高清在线观看| 麻豆91在线播放| 日韩黄色大片| 亚洲久久一区| 亚洲精品福利电影| 天堂va蜜桃一区二区三区| 天海翼精品一区二区三区| 丰满少妇一区| 日韩午夜av在线| 国产不卡精品在线| 国产中文在线播放| 日本国产欧美| 久久在线电影| 国产精品1区| 国产亚洲亚洲| 在线观看精品| 精品国产第一福利网站| 国产精品久久乐| 综合欧美精品| 日韩国产在线| 老司机免费视频一区二区| 视频一区在线播放| 麻豆久久久久久| 亚洲一区二区日韩| 不卡中文一二三区| 精品视频亚洲| 亚洲开心激情| 在线视频精品| 在线看片不卡| 九九综合九九| 欧美亚洲激情| 国产99在线| 国产精品色婷婷在线观看| 日韩专区欧美专区| 欧美 日韩 国产精品免费观看| 成人国产精选| 免费一级欧美在线观看视频| 视频一区在线播放| 中文在线日韩| 蜜桃视频免费观看一区| 九色porny丨国产首页在线| 欧美一区影院| 91成人在线网站| 视频一区日韩精品| 国产精品v一区二区三区| 97成人超碰| 综合精品一区| 亚洲精品少妇| 亚洲精品影视| 欧美女激情福利| 久久av一区| 国产精品三级| 日韩美女国产精品| 亚洲精品在线a| 日本亚洲最大的色成网站www| 欧美日韩网址| 欧美国产另类| 欧美亚洲国产激情| 亚洲主播在线| 国产精品黄色| 午夜久久久久| 激情久久久久久| 中文无码日韩欧| 久久精品99国产精品| 福利精品在线| 性欧美精品高清| 国产高清亚洲| 成人在线免费观看91| 欧美日韩国产在线观看网站| 日韩av中文在线观看| 久久久久久网| 中文字幕亚洲影视| 韩国精品主播一区二区在线观看| 一区免费在线| 国产66精品| 日本亚洲最大的色成网站www | 日韩影院精彩在线| 在线看片日韩| 免费观看亚洲天堂| 免费国产亚洲视频| 日韩一区二区三区免费播放| 日本美女一区| 久久一区国产|