使用AXIOS的ONUPLOADPROGRESS制作上传进度条--以及ONUPLOADPROGRESS的源码解读

1,从名字就可以看出来,这是允许为上传处理进度的事件。他是axios的请求配置之一。

axios({
        method: 'post',
        url: this.uploadurl,
        data: formData,
        headers: {
          'Content-Type': 'multipart/form-data' // 文件上传
        },
        //文件上传进度值
        onUploadProgress: function(progressEvent) {
          let complete = parseInt((progressEvent.loaded / progressEvent.total) * 100)
          that.percent = complete
        }
      })
        .then(data => {
          if (data.code == 200 && this.percent==100) {
            this.$message.info('上传成功!')
            this.fileList = []
            this.spinning = false
            this.intofloder(this.currentdir[this.currentdir.length - 1])
            let that = this
            //2秒后关闭上传窗口
            setTimeout(function(){
              that.upvisible=false
            },2000)
          } else {
            this.$message.info(data.message)
            this.spinning = false
          }
        })

2,progress.loaded表示当前上传的数据大小,progress.total表示整个要上传的数据大小。拿到当前上传数据的百分比后传给Element的进度条组件就可以实现啦

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值