【前端】上传和下载zip文件,有进度条(el-progess)

文章目录

场景:要上传一个zip,调用接口,然后下载一个zip。调用接口的接口响应要显示在进度条中。

上传

上传用的是input原生控件,在页面中隐藏。accept="application/zip"限制只能上传zip。

点击button实现上传,调用input原生组件的方法。

html 复制代码
<el-button
   type="primary"
   size="large"
   @click="uploadSrt"
   >上传srt</el-button
>
<input
   ref="srtInput"
   type="file"
   style="display: none"
   accept="application/zip"
   @change="handleUploadSrt"
 />

在event中拿到上传的文件file。

注意 ,要使用formData和'Content-Type': 'multipart/form-data',以支持二进制的传输。

不能用application/json的响应头,File对象不能被序列化为JSON。

详情看注释。

javascript 复制代码
uploadSrt() {
    this.$refs.srtInput.click()
},
// input原生控件的上传事件,file是拿到的文件
handleUploadSrt(event) {
    const file = event.target.files[0]
    this.upload(file)
},

upload(file) {
    // 用FormData,支持二进制数据传输
    let formData = new FormData()
    formData.append('file', file)

    axios
        .post('url', formData, {
        headers: {
            'Content-Type': 'multipart/form-data',
        },
        //   进度条进度
        onDownloadProgress: (progressEvent) => {
            if (progressEvent.total > 0) {
                this.srtProgress = Math.round((progressEvent.loaded * 100) / progressEvent.total)
            } else {
                this.srtProgress = 100 // 防止progressEvent.total为0出现无限大
            }
        },
        timeout: 10000, // 设置超时时间,若接口在10s内没响应就抛出异常,在catch中捕获
    })
        .then((response) => {
        // 响应后的逻辑
    })
        .catch((error) => {
        // 异常的逻辑
    })
},

下载

请求某个接口下载文件。

请求要设置参数,表示是二进制文件:responseType: 'blob'

创建一个url和a标签,点击a标签则下载。

javascript 复制代码
download(type) {
   let url = 'url'
   axios
     .get(url, { responseType: 'blob', timeout: 10000 })
     .then((res) => {
       const fileName='' // 设置下载的文件名
       // 创建一个下载url和a标签
       const downloadUrl = window.URL.createObjectURL(new Blob([res.data])) // res.data 是要下载的文件
       const link = document.createElement('a')
       link.href = downloadUrl
       // 设置download属性,点击链接就能下载
       link.setAttribute('download', `${fileName}`)
       // 将a标签加在文档中,点击下载
       document.body.appendChild(link)
       link.click()        
     })
     .catch((error) => {
       // ...
     })
 },

进度条

用ElementPlus的组件el-progress,传入一个srtProgress即可。不过效果是一下就闪到100了(可能是接口响应很快??)。

html 复制代码
<el-progress
  :percentage="srtProgress"
  status="warning"
  :stroke-width="12"
/>

最后改为,不要设置超时。给接口多一点时间,有道理!

相关推荐
前端扎啤4 分钟前
高效前端开发:解密pnpm的存储与链接
前端·前端框架·npm·pnpm·依赖
苏十八17 分钟前
前端基础:JavaScript(篇一)
开发语言·前端·javascript·面试·html·ecmascript·html5
narukeu23 分钟前
React 中 useState 和 useReducer 的联系和区别
前端·react.js·前端框架
38kcok9w2vHanx_31 分钟前
v-html 空格/换行不生效
前端·html
shootero@126.com1 小时前
npm常用命令
前端·npm·node.js
余十步1 小时前
Vue整合echarts
前端·vue.js·echarts
QD_ANJING1 小时前
2024年前端面试中面试官常拷打的“项目细节”!
前端·面试·职场和发展
粥里有勺糖2 小时前
「豆包Marscode体验官」MarsCode IDE 搭建 VitePress 博客并使用 GitHub 部署
前端·程序员·github
鱟鲥鳚2 小时前
SpringBoot设置自动跳转前端界面
前端·spring boot·后端
qb2 小时前
vue3响应式原理:reactive
前端·javascript·vue.js