最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Layui表格怎么实现根据行数据的某个值禁用该行的复选框方法
时间:2026-06-20 11:02:46 编辑:袖梨 来源:一聚教程网
需用templet自定义checkbox列并加disabled属性,同时手动过滤table.checkStatus()结果中被禁用的行,否则Layui仍会将其计入选中状态。
layui table 行内复选框禁用逻辑怎么写
直接在 cols 配置里加 checkbox 列时,layui 默认不支持按行数据动态禁用复选框。必须靠 templet 自定义渲染,并配合 disabled 属性手动控制。
如何用 templet 渲染带 disabled 的 checkbox
核心是放弃默认 checkbox 列,改用普通列 + 自定义模板,根据当前行的字段值决定是否加 disabled 属性。
- 把原
{type: 'checkbox'}列删掉,换成普通列,比如{field: 'status', title: '状态', templet: '#checkboxTpl'} - 在页面中定义
<script type="text/html" id="checkboxTpl">模板,里面写<input type="checkbox" name="layTableCheckbox" {{# if(d.status === 'closed'){ }} disabled {{# } }}> - 注意:
name="layTableCheckbox"是 Layui 内部识别多选的约定名,不能省;否则table.checkStatus()拿不到该行 - 如果用了
id或lay-id,记得同步写进 input,否则部分版本会漏触发事件
禁用后如何保证 table.checkStatus() 结果准确
自定义 checkbox 后,Layui 不会自动跳过被 disabled 的项——它仍会把它们算进“已勾选”或“全选状态”,除非你干预。
- 调用
table.checkStatus('yourId')前,先手动过滤掉disabled行:const data = table.cache['yourId']; const validChecked = data.filter(d => !d.status === 'closed' && d.LAY_CHECKED); - 不要依赖
data.count或data.data.length判断是否“全选”,得自己比对validChecked.length === data.filter(d => d.status !== 'closed').length - 如果启用了
checkStrictly: true,禁用行为不会影响父子联动,但依然要自己过滤结果
常见坑:disabled 失效或点击无反应
不是代码没生效,大概率是 DOM 更新时机或事件绑定冲突导致的。
- 模板里写了
disabled,但浏览器渲染后没生效 → 检查是否拼错了属性名(比如写成disable或disabeled) - 点击 checkbox 没反应,但 HTML 看起来有
disabled→ 确认没在 JS 里用$('input').prop('disabled', false)全局覆盖了 - 表格重载(
table.reload())后禁用丢失 → 模板必须在 reload 前已存在 DOM 中,不能动态 append script 标签 - 使用了
skin: 'row'或其它自定义皮肤 → 某些 CSS 可能遮盖了disabled的视觉反馈,建议加一行input[disabled]{opacity: 0.5; cursor: not-allowed;}
禁用逻辑本身简单,但和 Layui 的 checkbox 状态管理耦合得很深;最容易被忽略的是:禁用只是 UI 层面的限制,Layui 的内部选中状态、全选统计、甚至导出选中数据,都不会自动排除这些行——所有后续操作都得你自己补过滤。