国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue 中批量下載文件并打包的示例代碼

2024-05-06 15:24:16
字體:
來源:轉載
供稿:網友

思路: 用 ajax 將文件下載, 然后用 jszip 壓縮文件, 最后用 file-saver 生成文件

1. 準備工作

安裝 3 個依賴: axios, jszip, file-saver

yarn add axiosyarn add jszipyarn add file-saver

2. 下載文件

import axios from 'axios'const getFile = url => { return new Promise((resolve, reject) => { axios({  method:'get',  url,  responseType: 'arraybuffer' }).then(data => {  resolve(data.data) }).catch(error => {  reject(error.toString()) }) })}

這里需要注意的是responseType, 如果下載文件是文本類型的(如: .txt, .js之類的), 那么用responseType: 'text'也可以, 但是如果下載的文件是圖片, 視頻之類的, 就得用arraybuffer

3. 打包文件

import JSZip from 'jszip'import FileSaver from 'file-saver'export default { methods: { handleBatchDownload() {  const data = ['各類地址1', '各類地址2'] // 需要下載打包的路徑, 可以是本地相對路徑, 也可以是跨域的全路徑  const zip = new JSZip()  const cache = {}  const promises = []  data.forEach(item => {  const promise = getFile(item).then(data => { // 下載文件, 并存成ArrayBuffer對象   const arr_name = item.split("/")   const file_name = arr_name[arr_name.length - 1] // 獲取文件名   zip.file(file_name, data, { binary: true }) // 逐個添加文件   cache[file_name] = data  })  promises.push(promise)  })  Promise.all(promises).then(() => {  zip.generateAsync({type:"blob"}).then(content => { // 生成二進制流   FileSaver.saveAs(content, "打包下載.zip") // 利用file-saver保存文件  })  }) }, },}

4. 最終代碼

import axios from 'axios'import JSZip from 'jszip'import FileSaver from 'file-saver'const getFile = url => { return new Promise((resolve, reject) => { axios({  method:'get',  url,  responseType: 'arraybuffer' }).then(data => {  resolve(data.data) }).catch(error => {  reject(error.toString()) }) })}export default { render(h) { return (<a on-click={ () => this.handleBatchDownload() } href="javascript:;" rel="external nofollow" >批量下載</a>) }, methods: { handleBatchDownload() {  const data = ['各類地址1', '各類地址2'] // 需要下載打包的路徑, 可以是本地相對路徑, 也可以是跨域的全路徑  const zip = new JSZip()  const cache = {}  const promises = []  data.forEach(item => {  const promise = getFile(item).then(data => { // 下載文件, 并存成ArrayBuffer對象   const arr_name = item.split("/")   const file_name = arr_name[arr_name.length - 1] // 獲取文件名   zip.file(file_name, data, { binary: true }) // 逐個添加文件   cache[file_name] = data  })  promises.push(promise)  })  Promise.all(promises).then(() => {  zip.generateAsync({type:"blob"}).then(content => { // 生成二進制流   FileSaver.saveAs(content, "打包下載.zip") // 利用file-saver保存文件  })  }) }, },}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 西宁市| 彝良县| 九江市| 元谋县| 临夏市| 来安县| 大化| 竹溪县| 瑞丽市| 新和县| 南皮县| 长岭县| 临洮县| 和静县| 河南省| 苏尼特左旗| 昆山市| 车险| 祁阳县| 乌拉特中旗| 梓潼县| 乌兰察布市| 宜昌市| 武隆县| 榆中县| 绥德县| 高阳县| 乌拉特后旗| 江山市| 东方市| 邵阳市| 浙江省| 永济市| 盖州市| 忻城县| 将乐县| 冷水江市| 红河县| 金平| 日喀则市| 通辽市|