ホームページ > ウェブフロントエンド > jsチュートリアル > ファイルをバッチダウンロードして Vue にパッケージ化する方法の詳細な例

ファイルをバッチダウンロードして Vue にパッケージ化する方法の詳細な例

小云云
リリース: 2018-05-19 14:03:24
オリジナル
7832 人が閲覧しました

この記事では主に、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())
 })
 })
}
ログイン後にコピー

ここで注意する必要があるのは、ダウンロードされたファイルがテキスト タイプ (.txt、.js など) の場合、responseType: 'text' です。も使用できますが、ダウンロードしたファイルが写真やビデオなどの場合は、arraybuffer を使用する必要があります

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 = [&#39;各类地址1&#39;, &#39;各类地址2&#39;] // 需要下载打包的路径, 可以是本地相对路径, 也可以是跨域的全路径
  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保存文件
  })
  })
 },
 },
}
ログイン後にコピー
ダウンロードされたファイルが大きすぎると、パッケージ化に時間がかかり、ブラウザがクラッシュする可能性もあります。

関連する推奨事項:


Python はファイルのバッチ ダウンロードを実装します

php で複数のファイルをパッケージ化してダウンロードする 2 つの方法の例

Python スクリプト ファイルを実行可能ファイルにパッケージ化する方法

以上がファイルをバッチダウンロードして Vue にパッケージ化する方法の詳細な例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート