【前端】上传和下载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"
/>

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

相关推荐
蓝天白云下遛狗14 分钟前
goole chrome变更默认搜索引擎为百度
前端·chrome
come1123438 分钟前
Vue 响应式数据传递:ref、reactive 与 Provide/Inject 完全指南
前端·javascript·vue.js
musk12121 小时前
electron 打包太大 试试 tauri , tauri 安装打包demo
前端·electron·tauri
万少2 小时前
第五款 HarmonyOS 上架作品 奇趣故事匣 来了
前端·harmonyos·客户端
OpenGL2 小时前
Android targetSdkVersion升级至35(Android15)相关问题
前端
rzl023 小时前
java web5(黑马)
java·开发语言·前端
Amy.Wang3 小时前
前端如何实现电子签名
前端·javascript·html5
今天又在摸鱼3 小时前
Vue3-组件化-Vue核心思想之一
前端·javascript·vue.js
蓝婷儿3 小时前
每天一个前端小知识 Day 21 - 浏览器兼容性与 Polyfill 策略
前端
百锦再3 小时前
Vue中对象赋值问题:对象引用被保留,仅部分属性被覆盖
前端·javascript·vue.js·vue·web·reactive·ref