一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

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() 拿不到该行
  • 如果用了 idlay-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.countdata.data.length 判断是否“全选”,得自己比对 validChecked.length === data.filter(d => d.status !== 'closed').length
  • 如果启用了 checkStrictly: true,禁用行为不会影响父子联动,但依然要自己过滤结果

常见坑:disabled 失效或点击无反应

不是代码没生效,大概率是 DOM 更新时机或事件绑定冲突导致的。

  • 模板里写了 disabled,但浏览器渲染后没生效 → 检查是否拼错了属性名(比如写成 disabledisabeled
  • 点击 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 的内部选中状态、全选统计、甚至导出选中数据,都不会自动排除这些行——所有后续操作都得你自己补过滤

热门栏目