Vue 中批量下载文件并打包的示例代码

思路: 用 ajax 将文件下载, 然后用 jszip 压缩文件, 最后用 file-saver 生成文件

1. 准备工作

安装 3 个依赖: axios, jszip, file-saver

yarn add axios
yarn add jszip
yarn 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保存文件
  })
  })
 },
 },
}

注意:

如果下载的文件过大, 打包的时间将会很长, 甚至可能会导致浏览器奔溃

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容