vue+axios实现文件上传的实时进度条

 更新时间:2024年01月23日 08:26:59   作者:卢老师和马老师  
最近用vue写上传的时候,遇到一个需求就是页面上展示上传的进度条,之后写过一次,但是用的是假交互,直接从0-100,今天分享一下用axios自带的onUploadProgress来完成这个小需求,感兴趣的朋友可以参考下

前言

最近用vue写上传的时候,遇到一个需求就是页面上展示上传的进度条,之后写过一次,但是用的是假交互,直接从0-100,今天分享一下用axios自带的onUploadProgress来完成这个小需求。

封装

我们需要封装一下axios

export function uploadProgress(type, url, req, progress, timeout, headers) {
  let h = headers || {
    'Content-Type': 'application/json',
    BsmAjaxHeader: true,
  }
  const flag = url.includes('forward')
  h = setHeaderData(h, flag)
  const r = req || {}
  return axios({
    url: `paas-web${url}`,
    method: type,
    data: r,
    headers: h,
    timeout,
    onUploadProgress: progress,
  })
}

拿着这个方法在api文件夹内写接口的地方引用

  upload(req, back) {
    return uploadProgress(
      'POST',
      '/api/XXX/XXX',
      req,
      back
    )
  },

接着在你的vue文件内,引入upload方法在上传时调用

    this.upload(params, (progress) => {
              const progress1 = `${(
                (progress.loaded / progress.total) *
                100
              ).toFixed(2)}`;
              // 这里把值赋给data里的变量
              this.percentage = +progress1;
            })
            .then((res) => {
              if (res.data.code === 200) {
                   // 做相应的操作
              } else {
                  //  做相应的操作
              }
            })
            .finally(() => {
                 //这里要把值赋null 重置,也可以根据实际情况逻辑去定
              this.percentage = null;
            });

这个回调里面的progress就是返回的大小,需要自己拿到.loaded,.total计算一下

总结

我觉得重点在axios的onUploadProgress,具体去看axios官网怎么介绍这个api的,最后希望能帮助到各位,有什么错误地方也请评论指出

以上就是vue+axios实现文件上传的实时进度条的详细内容,更多关于vue+axios实时进度条的资料请关注脚本之家其它相关文章!

相关文章

  • vue+iview动态渲染表格详解

    vue+iview动态渲染表格详解

    这篇文章主要为大家详细介绍了vue+iview动态渲染表格的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • vue cesium加载点与定位到指定位置的实现方法

    vue cesium加载点与定位到指定位置的实现方法

    Cesium是一个用于创建高性能、跨平台的3D地球和地图的开源JavaScript库,它提供了许多功能,包括地理空间数据可视化、地理定位和地图导航等,这篇文章主要介绍了vue cesium加载点与定位到指定位置,需要的朋友可以参考下
    2024-03-03
  • 详解如何在nuxt中添加proxyTable代理

    详解如何在nuxt中添加proxyTable代理

    这篇文章主要介绍了详解如何在nuxt中添加proxyTable代理,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • 详解vue项目中使用vuedraggable

    详解vue项目中使用vuedraggable

    这篇文章主要介绍了vue项目中使用vuedraggable,本文给大家介绍了错误问题分析及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Vue3捕获和处理不同层级的异常/错误的有效方法

    Vue3捕获和处理不同层级的异常/错误的有效方法

    项目中如果没有对异常做处理,可能导致应用崩溃或显示报错信息影响用户体验,因此需要对不同层级的错误进行捕获,所以本文给大家介绍了Vue3捕获和处理不同层级的异常/错误的有效方法,需要的朋友可以参考下
    2025-01-01
  • Vue3中各种灵活传递数据的方式小结

    Vue3中各种灵活传递数据的方式小结

    Vue 3 提供了多种数据传递的方式,让我们的组件之间可以尽情地交流,接下来,我们就直接一个个来看,这些方式都是怎么工作的,感兴趣的小伙伴跟着小编一起来看看吧
    2024-07-07
  • Vue+Video.js实现视频抽帧并返回抽帧图片Base64

    Vue+Video.js实现视频抽帧并返回抽帧图片Base64

    这篇文章主要为大家详细介绍了Vue如何利用Video.js实现视频抽帧并返回抽帧图片Base64,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2024-01-01
  • vue之computed的缓存特性

    vue之computed的缓存特性

    这篇文章主要介绍了vue之computed的缓存特性,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • vue实现公告消息横向无缝循环滚动

    vue实现公告消息横向无缝循环滚动

    这篇文章主要为大家详细介绍了vue实现公告消息横向无缝循环滚动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • 使用vue实现点击按钮滑出面板的实现代码

    使用vue实现点击按钮滑出面板的实现代码

    这篇文章主要介绍了使用vue实现点击按钮滑出面板的实现代码,非常不错,具有参考借鉴价值,需要的朋友参考下
    2017-01-01

最新评论