axios 获取上传进度_axios+Vue上传文件显示进度

本文介绍了在Vue项目中利用axios进行文件上传并实时显示进度的方法。通过监听onUploadProgress事件,结合FormData处理文件,展示上传进度条。同时强调了在进度达到100%时需等待后台响应确认,以防用户提前关闭浏览器导致上传失败。
摘要由CSDN通过智能技术生成

一,前言

最近在用Vue,然后上传文件时需要显示进度,于是网上搜了一下,经过自己实测终于也弄明白了

二,效果

236def61390c8293219920f74becdc6d.png

三,代码

HTML代码

上传文件:

{{filename}}

+请选择文件上传+

上传进度:

{{(uploadRate*100).toFixed(2)}}%

CSS代码

.input-zone { width: 500px; color: blue; font-size: 14px; position: relative; }

.input-zone input[type='file'] { opacity: 0; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2; }

.progress-wrapper { position: relative; height: 50px; border-radius: 5px; background-color: lightgrey; }

.progress-wrapper .progress-progress { position: absolute; left: 0; top: 0; height: 100%; width: 0%; border-radius: 5px; background-color: darkturquoise; z-index: 1; }

.progress-wrapper .progress-rate { position: relative; text-align: center; font-size: 14px; line-height: 50px; height: 100%; z-index:2;}

JS代码

var app = new Vue({

el: "#app",

data: {

uploadRate: 0,

filename: '',

uploadStyle: {

width: '0%'

}

},

methods: {

upload: function (e) {

var vm = this;

var formData = new FormData();

formData.append("name", "Alax");

for (var i = 0; i < e.target.files.length; i++) {

var file = e.target.files[i]; //取第1个文件

formData.append("file", file);

vm.filename = file.name;

console.log(file);

}

var config = {

headers: { 'Content-Type': 'multipart/form-data' },

onUploadProgress: function (e) {

console.log("进度:");

console.log(e);

//属性lengthComputable主要表明总共需要完成的工作量和已经完成的工作是否可以被测量

//如果lengthComputable为false,就获取不到e.total和e.loaded

if (e.lengthComputable) {

var rate = vm.uploadRate = e.loaded / e.total; //已上传的比例

if (rate < 1) {

//这里的进度只能表明文件已经上传到后台,但是后台有没有处理完还不知道

//因此不能直接显示为100%,不然用户会误以为已经上传完毕,关掉浏览器的话就可能导致上传失败

//等响应回来时,再将进度设为100%

vm.uploadRate = rate;

vm.uploadStyle.width = (rate *100).toFixed(2)+ '%';

}

}

}

};

axios.post("/ajaxPage/VueUpload.aspx?method=upload", formData, config)

.then(function (data) {

console.log(data);

var json = data.data; //后台实际返回的结果

if (json.result) {

vm.uploadRate = 1;

vm.uploadStyle.width = '100.00%';

} else {

alert(json.msg);

}

})

.catch(function (err) {

console.log(err);

});

}

}

})

四,总结

1.其实单文件上传和多文件上传的区别就是 input标签中多了一个属性

multiple="multiple"

2.onuploadprogress 事件中显示上传为100%并不准确,一定要等到响应回来才能认为完成了100%,不然用户此时关闭了浏览器的话,上传就失败了。或者有其它逻辑时,此时点提交,就会导致后台找不到上传的文件路径等问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值