js php 批量下载文件,实例详解Vue 中批量下载文件并打包方法

本文主要介绍了Vue 中批量下载文件并打包的示例代码,用 ajax 将文件下载, 然后用 jszip 压缩文件, 最后用 file-saver 生成文件,有兴趣的可以了解一下,希望能帮助到大家。

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

1. 准备工作

安装 3 个依赖: axios, jszip, file-saveryarn 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 ( this.handleBatchDownload() } href="javascript:;" rel="external nofollow" >批量下载)

},

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保存文件

})

})

},

},

}

注意:

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

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值