axios+Vue實現(xiàn)上傳文件顯示進度功能
一,前言
最近在用Vue,然后上傳文件時需要顯示進度,于是網(wǎng)上搜了一下,經(jīng)過自己實測終于也弄明白了
二,效果

三,代碼
HTML代碼
<div id="app">
<h4>上傳文件:</h4>
<p class="input-zone">
<span v-if="filename">{{filename}}</span>
<span v-else>+請選擇文件上傳+</span>
<input type="file" name="file" value="" placeholder="請選擇文件" @change="upload" multiple="multiple" />
</p>
<p>上傳進度:</p>
<div class="progress-wrapper">
<div class="progress-progress" :style="uploadStyle"></div>
<div class="progress-rate">{{(uploadRate*100).toFixed(2)}}%</div>
</div>
</div>
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主要表明總共需要完成的工作量和已經(jīng)完成的工作是否可以被測量
//如果lengthComputable為false,就獲取不到e.total和e.loaded
if (e.lengthComputable) {
var rate = vm.uploadRate = e.loaded / e.total; //已上傳的比例
if (rate < 1) {
//這里的進度只能表明文件已經(jīng)上傳到后臺,但是后臺有沒有處理完還不知道
//因此不能直接顯示為100%,不然用戶會誤以為已經(jīng)上傳完畢,關掉瀏覽器的話就可能導致上傳失敗
//等響應回來時,再將進度設為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.其實單文件上傳和多文件上傳的區(qū)別就是 input標簽中多了一個屬性
multiple="multiple"
2.onuploadprogress 事件中顯示上傳為100%并不準確,一定要等到響應回來才能認為完成了100%,不然用戶此時關閉了瀏覽器的話,上傳就失敗了?;蛘哂衅渌壿嫊r,此時點提交,就會導致后臺找不到上傳的文件路徑等問題。
總結
以上所述是小編給大家介紹的axios+Vue實現(xiàn)上傳文件顯示進度功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關文章
VUE使用router.push實現(xiàn)頁面跳轉和傳參方式
這篇文章主要介紹了VUE使用router.push實現(xiàn)頁面跳轉和傳參方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01
vue動態(tài)的 BreadCrumb 組件el-breadcrumb ElementUI詳解
這篇文章主要介紹了vue如何做一個動態(tài)的 BreadCrumb 組件,el-breadcrumb ElementUI2024-07-07
,本文通過圖文示例代碼相結合給大家介紹的非常詳細,需要的朋友可以參考下
vue開發(fā)調(diào)試神器vue-devtools使用詳解
這篇文章主要為大家詳細介紹了vue開發(fā)調(diào)試神器vue-devtools的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

