使用axios實現(xiàn)上傳圖片進度條功能
Axios 是一個基于 promise 的 HTTP 庫,可以用在瀏覽器和 node.js 中。
Features
從瀏覽器中創(chuàng)建 XMLHttpRequests
從 node.js 創(chuàng)建 http 請求
支持 Promise API
攔截請求和響應(yīng)
轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
取消請求
自動轉(zhuǎn)換 JSON 數(shù)據(jù)
客戶端支持防御 XSRF
下面給大家介紹使用axios實現(xiàn)上傳圖片進度條功能,具體內(nèi)容介紹如下所示:
在最近做的項目中,一個手機頁面最多要上傳幾十張圖片,雖然對照片做了壓縮處理,不過最后還是很大,如果網(wǎng)卡的話,上傳的時間很差,如果一直在loading的話,用戶都不知道什自己上傳了多少,為了更直觀的展現(xiàn)上傳的進度,最好顯示進度條,和顯示上傳的百分比;
項目用的是vuejs框架,mint-ui做為ui框架;請求的是vue官方推薦的axios(真的很強大);在axios官方介紹了使用原生上傳處理進度事件(具體參考這里,這里有中文的axios官方介紹):
onUploadProgress: function (progressEvent) { // 對原生進度事件的處理 },
因為使用vuejs,對于接口的數(shù)據(jù)請求,為方便管理,需要統(tǒng)一的管理。如果放在每個組件里,不方便日后的維護和管理;在reqwest.js文件里,定義了一個uploadPhoto方法,該方法有三個參數(shù),分別是參數(shù),和兩個回調(diào)函數(shù),參數(shù)就是我們要上傳圖片的需要的額參數(shù);而第一個回調(diào)函數(shù),是獲取上傳進度包含的數(shù)據(jù),第二回調(diào)是獲取上傳成功失敗,后臺返回的數(shù)據(jù);來進行頁面的下一步操作。
uploadPhoto(payload,callback1,callback2){ axios({ url:BASE_URL + '/handler/material/upload', method:'post', onUploadProgress:function(progressEvent){ //原生獲取上傳進度的事件 if(progressEvent.lengthComputable){ //屬性lengthComputable主要表明總共需要完成的工作量和已經(jīng)完成的工作是否可以被測量 //如果lengthComputable為false,就獲取不到progressEvent.total和progressEvent.loaded callback1(progressEvent); } }, data:payload }).then(res =>{ callback2(res.data); }).then(error =>{ console.log(error) }) }
使用mint-ui組件里的Progress組件,在data的方法里定義該組件里的變量precent,該變量是number類型,在定義的時候,注意;
<mt-progress :value="precent" :bar-height="10"> <div slot="end">{{Math.ceil(precent)}}%</div> </mt-progress>
把reqwest.js 這個文件import 進來,獲取到uploadPhoto這個方法,根據(jù)獲取上傳的進度,使用$nextTick 這個屬性,實時的更新的頁面上。
const _this = this; API.uploadPhoto(fd,(res) =>{ let loaded = res.loaded, total = res.total; _this.$nextTick(() =>{ _this.precent = (loaded/total) * 100; }) },(res) =>{ if(res.code === '200'){ MessageBox.alert('圖片上傳成功').then(action => { console.log('ok'); }); } })
根據(jù)上面的方法基本實現(xiàn)圖片的上傳進度和百分比的顯示,剩下的就是ui了,根據(jù)自己個性化定制來實現(xiàn)你那完美的需求...
總結(jié)
以上所述是小編給大家介紹的使用axios實現(xiàn)上傳圖片進度條功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
JavaScript使用面向?qū)ο髮崿F(xiàn)的拖拽功能詳解
這篇文章主要介紹了JavaScript使用面向?qū)ο髮崿F(xiàn)的拖拽功能,結(jié)合實例形式詳細分析了javascript基于面向?qū)ο蟮耐献Чδ軐崿F(xiàn)思路、原理與具體操作技巧,需要的朋友可以參考下2019-06-06js調(diào)試工具 Javascript Debug Toolkit 2.0.0版本發(fā)布
Javascript Debug Toolkit是一個可以跨瀏覽器調(diào)試javascript的開源項目,支持在IE,FIREFOX,SAFARI,CHROME等瀏覽器中調(diào)試javascript。2.0.0版本做了較大變動,增加以下功能2008-12-12JavaScript?中的單例內(nèi)置對象Global?與?Math
這篇文章主要介紹了JavaScript?中的單例內(nèi)置對象Global與Math,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07JavaScript實現(xiàn)的Tween算法及緩沖特效實例代碼
這篇文章主要介紹了JavaScript實現(xiàn)的Tween算法及緩沖特效,涉及JavaScript通過數(shù)學(xué)運算及樣式屬性操作實現(xiàn)緩動、彈性運動等效果,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11js使用html()或text()方法獲取設(shè)置p標簽的顯示的值
html()方法可以用來讀取或者設(shè)置某個元素中的HTML內(nèi)容,text()方法可以用來讀取或者沒置某個元素中的文本內(nèi)容2014-08-08JavaScript中通過array.filter()實現(xiàn)數(shù)組的數(shù)據(jù)篩選、數(shù)據(jù)清洗和鏈式調(diào)用(JS數(shù)組過濾器的使用示例)
文章介紹了array.filter()方法的使用和技巧,強調(diào)了其在數(shù)據(jù)篩選、數(shù)據(jù)清洗和鏈式調(diào)用中的優(yōu)勢,本文介紹JavaScript中通過array.filter()實現(xiàn)數(shù)組的數(shù)據(jù)篩選、數(shù)據(jù)清洗和鏈式調(diào)用,JS中數(shù)組過濾器的使用詳解,感興趣的朋友一起看看吧2024-11-1141個Web開發(fā)者必須收藏的JavaScript實用技巧
41個Web開發(fā)者必須收藏的JavaScript實用技巧,分享給大家,感興趣的小伙伴們可以參考一下2016-07-07