需用templet自定义checkbox列并加disabled属性,同时手动过滤table.checkStatus()结果中被禁用的行,否则Layui仍会将其计入选中状态。
直接在 cols 配置里加 checkbox 列时,layui 默认不支持按行数据动态禁用复选框。必须靠 templet 自定义渲染,并配合 disabled 属性手动控制。
核心是放弃默认 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,否则部分版本会漏触发事件自定义 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,禁用行为不会影响父子联动,但依然要自己过滤结果不是代码没生效,大概率是 DOM 更新时机或事件绑定冲突导致的。
disabled,但浏览器渲染后没生效 → 检查是否拼错了属性名(比如写成 disable 或 disabeled)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 的内部选中状态、全选统计、甚至导出选中数据,都不会自动排除这些行——所有后续操作都得你自己补过滤。