解決elementui上傳組件el-upload無法第二次上傳問題
elementui上傳組件el-upload無法第二次上傳
無需上傳服務(wù)器的文件取消或者再次上傳時(shí)失效的問題
<el-upload class="upload-demo" ref="upload" drag action="" :limit="1" accept=".csv" :show-file-list="false" :before-upload="onClickCsvBeforeupload"> ?? ?<i class="el-icon-upload"></i> ?? ?<div class="el-upload__text">點(diǎn)這,或者拖到著</em></div> </el-upload>
在組件中添加ref="upload"屬性,無法第二次上傳,主要原因是瀏覽器還保存著,我們已經(jīng)上傳的文件(無論你是否符合你的要求)。
敲黑板!?。?!
this.$children[0].$children[0].$refs.upload.clearFiles();
主要是我們沒有清除文件造成的,可以根據(jù)你的項(xiàng)目,用Document找到refs,然后參照上面的做法就可以再次上傳了。困擾了我好久的問題,希望能幫到你。
el upload組件 第二次上傳請(qǐng)求無效,非clearFiles方法
開發(fā)時(shí)遇到一個(gè)業(yè)務(wù)需求:

導(dǎo)入時(shí)如果當(dāng)前列表月份存在數(shù)據(jù)將會(huì)提示用戶是否要覆蓋當(dāng)前數(shù)據(jù),點(diǎn)擊確定進(jìn)行二次提交
直接調(diào)用 submit 會(huì)無響應(yīng)
this.$confirm(`${response.msg},是否繼續(xù)?`, '提示', {
confirmButtonText: 確定,
cancelButtonText: 取消,
type: 'warning'
}).then((res) => {
// 直接提交會(huì)無響應(yīng)
this.$refs.upload.submit();
}).catch(() => {})查詢其他資料會(huì)發(fā)現(xiàn) 大多數(shù)會(huì)讓你 調(diào)用
this.$refs["upload"].clearFiles()
這樣的話會(huì)讓用戶重新添加,那么如何去節(jié)省該步驟呢?
當(dāng)?shù)谝淮紊蟼鞒晒蠡卣{(diào) on-success 方法 可以獲取到上傳的文件,這時(shí)可以進(jìn)行保存

觀察el-upload組件源碼會(huì)發(fā)現(xiàn)存儲(chǔ)文件的字段是 uploadFiles
el-upload組件部分源碼:

因此可以自行調(diào)用該方法,去主動(dòng)觸發(fā)handleStart()方法進(jìn)行上傳
最后貼上正確步驟
this.$confirm(`${response.msg},是否繼續(xù)?`, '提示', {
confirmButtonText: 確定,
cancelButtonText: 取消,
type: 'warning'
}).then((res) => {
// 先刪除
this.$refs["upload"].clearFiles()
this.$nextTick(() => {
// 再導(dǎo)入
this.$refs["upload"].handleStart(this.fileList[0].raw)
this.isUpdateSupport = 1
// 再提交上傳
this.$refs.upload.submit();
})
}).catch(() => {})User-agent: * Disallow: /
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue組件中iview的modal組件爬坑問題之modal的顯示與否應(yīng)該是使用v-show
這篇文章主要介紹了vue組件中iview的modal組件爬坑問題之modal的顯示與否應(yīng)該是使用v-show,本文通過實(shí)例圖文相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
vue中marker被識(shí)別點(diǎn)擊的過程場景分析
這篇文章主要介紹了vue中marker被識(shí)別點(diǎn)擊的過程場景分析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11
vue3全局組件自動(dòng)注冊(cè)功能實(shí)現(xiàn)
本文主要講述vue3的全局公共組件的自動(dòng)注冊(cè)功能,本文分步驟結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-02-02
詳解vue項(xiàng)目打包后通過百度的BAE發(fā)布到網(wǎng)上的流程
這篇文章主要介紹了將vue的項(xiàng)目打包后通過百度的BAE發(fā)布到網(wǎng)上的流程,主要運(yùn)用的技術(shù)是vue+express+git+百度的應(yīng)用引擎BAE。需要的朋友可以參考下2018-03-03

