您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在vue中利用element實現(xiàn)表格批量刪除功能,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
復制代碼 代碼如下:
<el-table @row-click="handleCurrentChange" @selection-change="selsChange" ref="table" :data="pageData" stripe :default-sort="{prop: 'createAt', order: 'descending'}" @sort-change="sortChange">
如圖所示,表格最前面有一個復選框
代碼很簡單
<el-table-column type="selection" width="65"></el-table-column>
刪除按鈕的代碼如下:
復制代碼 代碼如下:
<el-button v-show="mode == 'list'" class="small" type="warning" size="small" @click="removeBatch(sels)" :disabled="this.sels.length === 0||this.disabled">批量刪除</el-button>
data的代碼如下:
data() { return { pageSize: 12, total: 0, pageData: [], query: '', sort: 'createAt', order: 'descending', defaultSnap: srcFallback, accept: '', ws: null, sels: [],//選中顯示的值 disabled:true }; }
表格中的視頻數(shù)據(jù)來自于pageData,每個視頻都是一個對象,對象的status屬性等于waiting或者有progress屬性時,此視頻正在轉碼,或者正在準備轉碼,不允許刪除, 批量刪除就是把被選中的行添加到sels這個數(shù)組中,把數(shù)組里的每一個對象的id屬性組成一個數(shù)組,發(fā)送給后端,此外,正在轉碼的視頻不允許刪除,此時按鈕也是禁用狀態(tài)
根據(jù)官方文檔,@selection-change="selsChange"
是復選框選擇改變時觸發(fā)的事件
在methods中添加一個方法
selsChange(sels) { //被選中的行組成數(shù)組 this.sels = sels; //遍歷被選中行數(shù)所組成的數(shù)組 for(let element of this.sels){ //如果視頻正在轉碼或者等待轉碼,禁用按鈕,結束方法 if(element.status == 'waiting'||element.progress){ this.disabled = true; return; } //如果沒有視頻正在轉碼或者等待轉碼,按鈕可用 this.disabled = false; } }
把請求發(fā)送給后端,代碼如下:
removeBatch(rows){ var ids = []; rows.forEach(element =>{ ids.push(element.id) }) this.$confirm('確定要刪除選中的文件嗎?','提示').then(() =>{ $.post('/vod/removeBatch',{ ids:ids }).then(dara =>{ this.updateData(); }) }).catch(()=>{}); }
前端已經排除正在轉碼的視頻了,后端是否能根據(jù)前端傳來的數(shù)據(jù),直接刪除視頻呢?
答案是不可以,后端一樣要做驗證
思路是,拿到前端傳來的數(shù)據(jù)后,遍歷數(shù)組兩次,第一次如果發(fā)現(xiàn)有正在轉碼的視頻,拋出異常,不會進入第二次循環(huán),第二次循環(huán)才根據(jù)id刪除視頻
代碼如下
r.post('/removeBatch',async(req,res) => { var ids = req.body.ids; var files = utils.vod.get("files"); //第一次循環(huán),如果有正在轉碼的文件,就拋出異常,結束循環(huán) for(let id of ids){ var transing = trans.agent.transing[id]; if(transing){ throw new Error('正在轉碼的文件無法刪除'); return; } } //如果沒有轉碼的文件,進入第二次循環(huán) for(let id of ids){ var files = utils.vod.get("files"); var row = files.find({id: id}).cloneDeep().value(); //如果沒有要刪除的,就結束 if(!row) { res.sendStatus(200); return; } var dir = path.dirname(row.path); var name = path.basename(row.path, path.extname(row.path)); var transDir = path.resolve(dir, name); //刪除源文件 if(fs.existsSync(row.path)){ fs.removeSync(row.path); } //刪除轉碼文件 if(fs.existsSync(transDir)){ fs.removeSync(transDir); } //刪除json文件記錄 files.remove({id: id}).write(); } res.sendStatus(200); })
關于怎么在vue中利用element實現(xiàn)表格批量刪除功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。