成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

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

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

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

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

2.將blob壓縮為zip

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

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

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

添加依賴

//npm install jszip

//npm install file-saver

在頁面的script中引入依賴

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) => { //通過請(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 生成二維碼并且批量打包下載代碼

我就廢話不多說了,大家還是直接看代碼吧~

<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)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
日韩一区二区三区电影| 欧美大片一区| 国自产拍偷拍福利精品免费一| 欧美xingq一区二区| 国产一区二区免费在线| 欧美亚洲动漫精品| 日韩精品亚洲专区| 久久野战av| 婷婷一区二区三区| 91视频在线观看| www国产成人免费观看视频 深夜成人网| 国产精品小仙女| 欧美日韩久久久一区| 久久99精品国产麻豆婷婷洗澡| 欧美性色aⅴ视频一区日韩精品| 美女诱惑一区二区| 色噜噜狠狠色综合欧洲selulu| 天天操天天干天天综合网| 亚洲欧美日韩国产一区二区| 亚洲一区av在线| 午夜亚洲性色视频| 日韩国产成人精品| 欧美这里有精品| 久久99国产精品麻豆| 欧美日韩二区三区| 国产一区二区精品久久99| 3d成人动漫网站| 成人午夜激情在线| 国产午夜精品美女毛片视频| 狠狠入ady亚洲精品| 综合激情网...| 亚洲精品美女91| 亚洲一区二区av在线| 久久久www| 男女男精品网站| 欧美日韩小视频| 福利电影一区二区| 久久久久久毛片| 欧美日韩一区综合| 依依成人精品视频| 亚洲一区日韩在线| 视频在线在亚洲| 色噜噜狠狠一区二区三区果冻| 日韩高清不卡在线| 欧美精品一级二级三级| 成人激情电影免费在线观看| 国产午夜精品在线观看| 亚洲国产二区| 日韩精品成人一区二区在线| 欧美日韩国产一级| 99re热这里只有精品视频| 一区免费观看视频| 久久久久久9| 国产精品中文字幕欧美| 久久久亚洲综合| 日韩午夜av| 一区二区三区免费在线观看| 久久最新视频| 粉嫩一区二区三区在线看 | 国产欧美va欧美不卡在线| 精品不卡在线| 丝瓜av网站精品一区二区| 欧美一区二区三区在线观看视频| 欧美.www| 日日噜噜夜夜狠狠视频欧美人| 日韩一区二区三区电影| 国自产拍偷拍福利精品免费一| 亚洲成人久久影院| 91精品国产免费| 亚洲高清毛片| 韩国视频一区二区| 国产精品国产三级国产有无不卡| 久久久99国产精品免费| 国产91清纯白嫩初高中在线观看| 国产精品久久久久久亚洲伦 | 日本va欧美va瓶| 日韩欧美一区二区视频| 亚洲午夜精品久久| 麻豆freexxxx性91精品| 久久日韩粉嫩一区二区三区| 日韩亚洲精品在线| 国产一区二区美女诱惑| 亚洲色图欧美偷拍| 欧美精品久久一区二区三区| 国产精品扒开腿做爽爽爽软件| 蜜桃精品视频在线观看| 中文字幕不卡三区| 日本韩国精品在线| 午夜久久资源| 久草中文综合在线| 国产精品精品国产色婷婷| 欧美三区在线观看| 欧美日韩一区自拍| 国产在线视频一区二区| 亚洲人精品午夜| 欧美一区二区精品| 亚洲欧美日韩视频二区 | 久久亚洲一区二区三区四区| 午夜一区二区三区不卡视频| 日韩成人av影视| 国产欧美日韩不卡| 欧美日韩亚州综合| 99在线精品视频在线观看| 国产精品小仙女| 亚洲一级电影视频| 久久精品人人做人人综合| 久久野战av| 国产综合视频| 国产电影一区二区三区| 亚洲国产精品久久人人爱蜜臀 | 首页国产丝袜综合| 久久亚洲免费视频| 91久久精品国产91性色tv| 色综合天天综合| 蜜桃传媒麻豆第一区在线观看| 国产精品美女久久久久高潮| 在线成人午夜影院| 99精品国产在热久久| www.99精品| 精品一区二区国语对白| 一区二区三区四区激情| 26uuu国产日韩综合| 欧美亚洲综合网| 夜夜爽av福利精品导航 | 久久精品一区二区| 欧美日韩一二区| 国产精品手机视频| 欧美精品首页| 成人毛片在线观看| 久久99久久99| 亚洲成av人**亚洲成av**| 国产精品视频yy9299一区| 日韩片之四级片| 欧美天堂亚洲电影院在线播放| 国产亚洲一区在线播放| 合欧美一区二区三区| 成人理论电影网| 另类成人小视频在线| 亚洲午夜激情网页| 亚洲天堂免费在线观看视频| 国产亚洲精品bt天堂精选| 欧美一级二级三级蜜桃| 欧美少妇性性性| 久久性天堂网| 亚洲尤物影院| 欧美性久久久| 成人av一区二区三区| 国模冰冰炮一区二区| 日韩成人免费电影| 亚洲v精品v日韩v欧美v专区| 综合电影一区二区三区| 中文在线资源观看网站视频免费不卡| 日韩一区二区中文字幕| 欧美人牲a欧美精品| 在线观看日韩电影| 色悠悠久久综合| 久久久久国内| 久久精品一区| 久久精品日韩| 久久婷婷丁香| 免费看黄裸体一级大秀欧美| 国产精品亚洲欧美| 国产精品手机视频| 国产嫩草一区二区三区在线观看| 亚洲精品乱码久久久久久蜜桃91| 国精品一区二区三区| 欧美~级网站不卡| 99久久伊人久久99| 成人h动漫精品一区二| 岛国一区二区三区| 成人精品视频.| a在线欧美一区| 色综合中文综合网| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 高清在线观看日韩| 国产精品综合网| 国产成人免费网站| 成人一区二区三区视频在线观看| 高清久久久久久| 99久久久久久99| 女生裸体视频一区二区三区| 色综合久久综合网欧美综合网 | 91.xcao| 欧美精品久久久久久久久老牛影院| 欧美视频一区在线| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲精品裸体| 在线亚洲伦理| 六月婷婷一区| 在线区一区二视频| 欧美日韩精品一区二区三区 | 欧美va在线播放| 精品美女一区二区三区| 久久精品视频在线看| 国产精品久久三区| 亚洲黄一区二区三区| 午夜激情久久久| 激情六月婷婷综合| jlzzjlzz国产精品久久| 欧美精品二区三区四区免费看视频|