新聞中心
一,前言
成都創(chuàng)新互聯(lián),為您提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、網(wǎng)站營(yíng)銷推廣、網(wǎng)站開(kāi)發(fā)設(shè)計(jì),對(duì)服務(wù)成都加固等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)及推廣經(jīng)驗(yàn)。成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司成立于2013年,提供專業(yè)網(wǎng)站制作報(bào)價(jià)服務(wù),我們深知市場(chǎng)的競(jìng)爭(zhēng)激烈,認(rèn)真對(duì)待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進(jìn)步,是我們永遠(yuǎn)的責(zé)任!
最近在用Vue,然后上傳文件時(shí)需要顯示進(jìn)度,于是網(wǎng)上搜了一下,經(jīng)過(guò)自己實(shí)測(cè)終于也弄明白了
二,效果
三,代碼
HTML代碼
上傳文件:
{{filename}} +請(qǐng)選擇文件上傳+
上傳進(jìn)度:
{{(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個(gè)文件 formData.append("file", file); vm.filename = file.name; console.log(file); } var config = { headers: { 'Content-Type': 'multipart/form-data' }, onUploadProgress: function (e) { console.log("進(jìn)度:"); console.log(e); //屬性lengthComputable主要表明總共需要完成的工作量和已經(jīng)完成的工作是否可以被測(cè)量 //如果lengthComputable為false,就獲取不到e.total和e.loaded if (e.lengthComputable) { var rate = vm.uploadRate = e.loaded / e.total; //已上傳的比例 if (rate < 1) { //這里的進(jìn)度只能表明文件已經(jīng)上傳到后臺(tái),但是后臺(tái)有沒(méi)有處理完還不知道 //因此不能直接顯示為100%,不然用戶會(huì)誤以為已經(jīng)上傳完畢,關(guān)掉瀏覽器的話就可能導(dǎo)致上傳失敗 //等響應(yīng)回來(lái)時(shí),再將進(jìn)度設(shè)為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; //后臺(tái)實(shí)際返回的結(jié)果 if (json.result) { vm.uploadRate = 1; vm.uploadStyle.width = '100.00%'; } else { alert(json.msg); } }) .catch(function (err) { console.log(err); }); } } })
四,總結(jié)
1.其實(shí)單文件上傳和多文件上傳的區(qū)別就是 input標(biāo)簽中多了一個(gè)屬性
multiple="multiple"
2.onuploadprogress 事件中顯示上傳為100%并不準(zhǔn)確,一定要等到響應(yīng)回來(lái)才能認(rèn)為完成了100%,不然用戶此時(shí)關(guān)閉了瀏覽器的話,上傳就失敗了?;蛘哂衅渌壿嫊r(shí),此時(shí)點(diǎn)提交,就會(huì)導(dǎo)致后臺(tái)找不到上傳的文件路徑等問(wèn)題。
總結(jié)
以上所述是小編給大家介紹的axios+Vue實(shí)現(xiàn)上傳文件顯示進(jìn)度功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
當(dāng)前標(biāo)題:axios+Vue實(shí)現(xiàn)上傳文件顯示進(jìn)度功能
網(wǎng)站URL:http://www.dlmjj.cn/article/jieiis.html