记录一次有关layui的bug修复,监听table内的input的动态变化并且修改表格

1.场景:

今天发现一个离职同事留下的bug,table的删除逻辑有问题。仔细一看,同事是通过获取table的行data的name数据的来配合删除的。但由于他在table内实现的input是动态变化的且没有实时修改表格的data,在此记录一下修改方案。

2.code:

typescript 复制代码
<table id="attributeTable" lay-filter="attributeTable">
      
</table>
-------------------------------------------------------------------------------------
<script type="text/html" id="inputNameTpl">
  <div class="layui-input-inline" style="width: 100%;">
    <input type="text" name="inputName" lay-verify="required" placeholder="请输入" autocomplete="off" class="layui-input table-input" value="{{d.name || ''}}">
  </div>
</script>
<script type="text/html" id="inputValueTpl">
  <div class="layui-input-inline" style="width: 100%;">
    <input type="text"  name="inputValue" placeholder="多属性用英文逗号隔开" autocomplete="off" class="layui-input table-input" value="{{d.nameCode || ''}}">
  </div>
</script>
-------------------------------------------------------------------------------------
    layui.use(['table', 'form'], function(){
      var tableHeight = $(document).height() > 800 ? $(document).height() - 575 : 430 ;
      layui.table.render({
        elem: '#attributeTable'
        ,id: 'attributeTable'
        ,height:tableHeight
        ,limit:100000
        ,data:App.addDttributeData
        ,cols:  [[
          {checkbox: true}
          ,{field: 'name', title: '属性名称',align:'center',templet: '#inputNameTpl'}
          ,{field: 'nameCode', title: '属性值',align:'center',templet: '#inputValueTpl'}

        ]]
      });
      // 监听表格单击事件
      layui.table.on('row(attributeTable)', function(obj){
        // 监听表格内input的修改事件
        $('.table-input').on('change',  function(){
          var value = $(this).val(); // 获取input的值
          var field = $(this).attr("name"); // 获取input的name值
          // 根据field更新原始数据
          if (field == "inputName"){
            obj.update({
              name: value,
            });
          } else if (field == "inputValue"){
            obj.update({
              nameCode: value,
            });
          }
          layui.table.reload("attributeTable", {
            scrollPos: 'fixed'
          });
        });
      });
    });
相关推荐
BY组态1 分钟前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态6 分钟前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart7 分钟前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe517 分钟前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒2 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu2 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿3 小时前
Spring Boot自动配置详解
java·大数据·前端
文心快码BaiduComate3 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
还有多久拿退休金3 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
光辉GuangHui3 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm