Vue使用el-upload批量上傳圖片時報錯問題處理方法
項目場景:
項目場景:項目中有一個文件上傳的場景,使用el-upload組件進行上傳,單圖上傳是正常,但是在進行批量上傳時報了錯。
問題描述
使用el-upload在進行多圖批量上傳時系統(tǒng)提示報錯。
報錯提示:
Uncaught TypeError: Cannot set properties of null (setting 'status')
at VueComponent.handleProgress (element-ui.common.js:29656:1)
at Object.onProgress (element-ui.common.js:29373:1)
at XMLHttpRequestUpload.progress (element-ui.common.js:29039:1)
原因分析:
在網(wǎng)上找了許多解決方案,有的說是因為el-upload組件file-list綁定的數(shù)組不可以手動修改,需要在on-success方法中使用另一個數(shù)組來存放文件,但實際操作下來還是有諸多問題,后來認真看了報錯信息,思考是否跟文件上傳時的狀態(tài)有關(guān)。
在on-success方法中將fileList console.log出來
Success (res, file, fileList) { console.log(fileList, 'fileList') }
發(fā)現(xiàn)當?shù)谝粡埳蟼魍瓿蓵r后面幾張的status的值都為ready,是否在on-success中回傳給file-list的值只取success狀態(tài)下的呢?導致on-success只觸發(fā)了一次,后面幾張因為status問題而不往下執(zhí)行了,于是決定使用every等所有圖片狀態(tài)都為success時再傳值給file-list。
解決方案:
使用every等所有圖片狀態(tài)都為success時再傳值給file-list
handleSuccess (res, file, fileList) { if (res.code == 200) { //參考如下代碼即可 if (fileList.every(item => item.status == "success")) { //由于fileList是所有的文件包含之前已上傳過的,這里需要做區(qū)分(帶response的即為新上傳的) fileList.map(item => { item.response && this.fileList.push({ name: item.name, fileId: item.response.data.name, url: item.response.data.url }); }) } this.$emit('input', this.fileList) } else { fileList.filter(o => o.uid != file.uid) this.$emit('input', this.fileList) this.$message({ message: res.msg, type: 'error', duration: 1500 }) } },
最后效果如下:
總結(jié)
到此這篇關(guān)于Vue使用el-upload批量上傳圖片時報錯問題處理方法的文章就介紹到這了,更多相關(guān)Vue el-upload批量上傳圖片報錯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue.js第一天學習筆記(數(shù)據(jù)的雙向綁定、常用指令)
這篇文章主要為大家分享了Vue.js第一天的學習筆記,包括數(shù)據(jù)的雙向綁定、常用指令學習,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12vue.js給動態(tài)綁定的radio列表做批量編輯的方法
下面小編就為大家分享一篇vue.js給動態(tài)綁定的radio列表做批量編輯的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02vue-socket.io接收不到數(shù)據(jù)問題的解決方法
這篇文章主要介紹了解決vue-socket.io接收不到數(shù)據(jù)問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05vue-cli與webpack處理靜態(tài)資源的方法及webpack打包的坑
這篇文章主要介紹了vue-cli與webpack處理靜態(tài)資源的方法,需要的朋友可以參考下2018-05-05