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

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

时间2025-06-19 05:15:46分类IT科技浏览6190
导读:获取数据后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
chatbots音标(ChatGPT API 调用教程) 提升网站曝光率的必杀技——SEO优化(SEO优化是营销效果的长期保障)