解決獲取數據后this.$refs.xxx.toggleRowSelection無效的問題
獲取數據后this.$refs.xxx.toggleRowSelection無效
獲取數據后在外部加上一個$nextTick即可
this.$nextTick(function () {
? this.trainPeopleTable.forEach(row=>{
? ? if(this.selectList.indexOf(row.staffId) >= 0){
? ? ? this.$refs.trainPersonTable.toggleRowSelection(row);
? ? }
? })
})原因大概如下:
$nextTick 是在下次 DOM 更新循環(huán)結束之后執(zhí)行延遲回調,在修改數據之后使用 $nextTick,則可以在回調中獲取更新后的 DOM
toggleRowSelection失效的2個原因
背景
當在含分頁的table中,需分頁切換后對列表項的勾選狀態(tài)做回顯操作。根據element文檔使用 this.$refs.mytable.toggleRowSelection(row, selected)方法回顯,實際應用時會出現(xiàn)回顯失效的情況。
失效原因
1、 ref 文檔本身是作為渲染結果被創(chuàng)建的,在初始渲染的時候你不能訪問它們 - 它們還不存在! $refs 也不是響應式的,因此你不應該試圖用它在模板中做數據綁定。
數據更新后Dom會注銷新建,導致我們勾選操作失效
2、我們操作的勾選數據必須是表單數據,即便數據一模一樣,數據存儲地址的指針不同也會導致失效
解決辦法
1、使用$nextTick,在dom 更新完成后的回調中來處理渲染選中

2、通過已選數據對比篩選表單數據來操作同一數據
this.checkedData.forEach(item => { // checkedData為已選數據
this.$nextTick( ()=>{
this.userData.find(obj => { // userData 表單數據
if(item.id === obj.id) {
this.$refs.multipleTable.toggleRowSelection(obj,true)
}
})
})
})
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vue項目中使用Hbuilder打包app 設置沉浸式狀態(tài)欄的方法
這篇文章主要介紹了vue項目 使用Hbuilder打包app 設置沉浸式狀態(tài)欄的方法,本文通過實例代碼效果圖展示給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2018-10-10
vue雙向錨點實現(xiàn)過程簡易版(scrollIntoView)
這篇文章主要介紹了vue雙向錨點實現(xiàn)過程簡易版(scrollIntoView),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
vue自定義js圖片碎片輪播圖切換效果的實現(xiàn)代碼
這篇文章主要介紹了vue自定義js圖片碎片輪播圖切換效果的實現(xiàn)代碼,需要的朋友可以參考下2019-04-04

