使用element组件table表格实现某条件下复选框无法勾选
作者:蓝胖子的多啦A梦
这篇文章主要介绍了使用element组件table表格实现某条件下复选框无法勾选问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
element组件table表格实现某条件下复选框无法勾选
需求
实现el-table
存在复选框,但在启用条件下无法勾选。
<el-table :data="dataList" ref="table" :row-class-name="tableRowClassName" :row-key="getRowKey" @selection-change="selectionChangeHandle" @sort-change="sortChangeHandle"> <el-table-column fixed="left" :selectable="checkSelect" :reserve-selection="true" type="selection" width="55" align="center"></el-table-column> </el-table>
//勾选置灰 checkSelect (row,index) { let isChecked = true; if (row.status== 'finish') { // 判断里面是否存在某个参数 //status==finish 时 该行复选框不可勾选 isChecked = false } else { isChecked = true } return isChecked }, //确定唯一的key值 getRowKey(row){ return row.id; //每条数据的唯一识别值 }, //字体颜色置灰 tableRowClassName({row,rowIndex}){ if (row.type === 1) { // 判断里面是否存在某个参数 return 'fontSize' } return '' },
<style> .el-table .fontSize{ color: #BFBABA; } </style>
Element Table组件复选框默认选中不生效
问题描述
获取到要默认选中的row后,直接使用:
this.$refs.multipleTable.toggleRowSelection(row)
发现并没有选中。
原因分析
Vue 在更新 DOM 时是异步执行的,使用上面的方法更新数据后,DOM并没有同步更新,所以没有显示出来。
官网是这样解释的:
Vue 异步执行 DOM 更新。只要观察到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据改变。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作上非常重要。然后,在下一个的事件循环“tick”中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部尝试对异步队列使用原生的 Promise.then 和MessageChannel,如果执行环境不支持,会采用 setTimeout(fn, 0)代替。
例如,当你设置vm.someData = ‘new value’,该组件不会立即重新渲染。当刷新队列时,组件会在事件循环队列清空时的下一个“tick”更新。多数情况我们不需要关心这个过程,但是如果你想在 DOM 状态更新后做点什么,这就可能会有些棘手。虽然 Vue.js 通常鼓励开发人员沿着“数据驱动”的方式思考,避免直接接触 DOM,但是有时我们确实要这么做。为了在数据变化之后等待 Vue 完成更新 DOM ,可以在数据变化之后立即使用Vue.nextTick(callback) 。这样回调函数在 DOM 更新完成后就会调用。
解决方案
改为:
this.$nextTick(() => { this.$refs.multipleTable.toggleRowSelection(row) })
将回调(这里是操作DOM更新选中数据)延迟到下次 DOM 更新循环之后执行。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。