首页IT科技获取数据失败请稍后再试(解决获取数据后this.$refs.xxx.toggleRowSelection无效的问题)

获取数据失败请稍后再试(解决获取数据后this.$refs.xxx.toggleRowSelection无效的问题)

时间2025-09-19 13:02:28分类IT科技浏览7523
导读:获取数据后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 更新循环结束之后执行延迟回调                   ,在修改数据之后使用 $nextTick                         ,则可以在回调中获取更新后的 DOM

toggleRowSelection失效的2个原因

背景

当在含分页的table中          ,需分页切换后对列表项的勾选状态做回显操作                 。根据element文档使用 this.$refs.mytable.toggleRowSelection(row, selected)方法回显               ,实际应用时会出现回显失效的情况                             。

失效原因

1                   、 ref 文档本身是作为渲染结果被创建的                         ,在初始渲染的时候你不能访问它们 - 它们还不存在! $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) } }) }) })

以上为个人经验     ,希望能给大家一个参考                           ,也希望大家多多支持本站            。

声明:本站所有文章                      ,如无特殊说明或标注,均为本站原创发布                             。任何个人或组织                       ,在未征得本站同意时                          ,禁止复制                         、盗用              、采集          、发布本站内容到任何网站                          、书籍等各类媒体平台             。如若本站内容侵犯了原著者的合法权益     ,可联系我们进行处理        。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
python等边三角形的绘制过程(python中如何绘制等边三角形)