vue项目中的上传与文件流下载

需求是实现一个上传文件,然后后端添加上水印,后返回一个zip我去下载。

第一步:上传

js 复制代码
        <md-tab id="tool" md-label="工具">
          <div v-loading="loading">
            <el-divider content-position="left">添加水印</el-divider>
            <div class="package">
              <el-form :inline="true" :model="conversionForm" class="demo-form-inline" :rules="conversionRules" ref="watermarkForm">
                <el-form-item label="水印文本" prop="watermark">
                  <el-input v-model="conversionForm.watermark" placeholder="请输入水印" maxlength="32"></el-input>
                </el-form-item>
                <el-form-item prop="conversionFile" class="upload-list">
                  <el-upload action="" multiple  :auto-upload="false"
                  accept=".pdf, .doc, .docx"
                    :on-change="handleChangeFile" ref="upload">
                    <el-button size="small" type="primary" slot="trigger">选取文件</el-button>
                  </el-upload>
                </el-form-item>
              </el-form>
              <el-button type="primary" @click="conversionUpload()">转换</el-button>
            </div>
          </div>
        </md-tab>
        
js 复制代码
handleChangeFile(file, fileList) {
      this.conversionForm.conversionFile = file.raw
      this.conversionForm.list = fileList.map(item => item.raw)
    },

结构代码如上,因为我们上传并不是直接上传,所以我们先把auto-upload设置成false,还要增加on-change事件,这样可以拿到我们需要的文件,并且我们上传完成之后我们还要下载,所以我们的接口也要设置一下,我们需要设置responseType为blob,这个我们后面要用。

js 复制代码
//增加文件水印
export const addFileWatermark = (data) => {
  return request({
    url: '/estimate/addWaterMark',
    method: 'post',
    data,
    responseType: 'blob'
  })
}

接下来看上传阶段

js 复制代码
 let formData = new FormData()
          this.conversionForm.list.forEach((file,index) => {
            formData.append(`files`,file)
          })
          formData.append('waterMark', this.conversionForm.watermark)
          addFileWatermark(formData)
            .then(({filename,blob}) => {
              download(blob,filename)
              this.loading = false
            })
            .catch(err => {
              console.log(err,'查看');
              this.loading = false
            })

这个就是上传的主要逻辑,上传就是new 一个formData,然后把file添加进去,虽然是多文件上传,但不能直接把on-change获取的fileList直接填到formData里,需要把fileList里的raw先取出来(这个才是文件)构成一个数组,然后foreach添加到formData里。 第二步:下载

js 复制代码
export function download(blob, filename) {
  const url = URL.createObjectURL(blob)
  const opt = {
    href: url
  }
  if (filename) {
    opt['download'] = filename
  }
  createElement('a', opt).click()
  URL.revokeObjectURL(url)
}

下载就比较简单,将.then后的参数解构 ,然后拿到文件名以及blob之后通过模拟点击a标签,进行下载。这下下载就结束了。

相关推荐
无心使然云中漫步3 分钟前
Openlayers调用ArcGis地图服务之五 —— 要素识别(/identify)
前端·arcgis·vue·数据可视化
zhensherlock14 分钟前
Protocol Launcher 系列:Beorg 高效任务管理的协议支持
前端·javascript·typescript·node.js·自动化·github·js
ppandss115 分钟前
JavaWeb从0到1-DAY3.1- Vue(ii)
前端·javascript·vue.js
M ? A15 分钟前
Vue 转 React | VuReact编译工具快速入门
前端·javascript·vue.js·后端·react.js·面试·vureact
qq_4275398318 分钟前
iframe 嵌入预览 PDF ,禁用右键菜单、打印下载按钮不展示
前端·javascript·vue.js·pdf
yu859395821 分钟前
降低OFDM系统PAPR的各种算法及误码率分析
前端·算法
ZC跨境爬虫21 分钟前
跟着 MDN 学 HTML day_3:(表单CSS美化实战与盒子模型三大核心属性详解)
前端·javascript·css·html
非科班Java出身GISer30 分钟前
ArcGIS Maps SDK for JavaScript 5.0 组件化开发指南
javascript·arcgis·components·arcgis js 组件化·arcgis js5.0·arcgis js5.0初始化
张风捷特烈31 分钟前
状态管理大乱斗#05 | Riverpod 源码评析 (中) - 上层建筑
android·前端·flutter