layui 复选框设置选中不好用

layui 复选框 设置 选中不好用,取值都正常,就是 设置选中状态 不好用,不知道问题出在哪里
JS 和 layui 代码如下

 var wc = $("#write_checkbox").val();
                                $("#write_checkbox").checked = true;
                                form.render();
                                console.log("复选框 值: " + wc);

 
="layui-form-item">
="layui-input-block"> ="checkbox" name="like[write]" id="write_checkbox" value="write_checkbox_value" title="写作"> ="checkbox" name="like[read]" title="阅读" checked=""> ="checkbox" name="like[game]" title="游戏">

根据你提供的代码,看起来问题出在这一行:

$("#write_checkbox").checked = true;

应该使用 jQuery 提供的 prop() 方法来设置复选框的选中状态,而不是直接使用 DOM 元素的属性 checked。因此,你可以尝试修改这一行代码如下:

$("#write_checkbox").prop("checked", true);

这样应该可以正确地设置复选框的选中状态了。如果还有问题,可以提供更多代码或者具体的错误信息,以便更好地帮助你解决问题。

该回答引用GPT:
layui复选框设置选中不好用,可能是因为没有正确获取到复选框的值,导致设置选中状态失败。

应该改为:

var wc = $("#write_checkbox").val();
$("#write_checkbox")[0].checked = true;
form.render();
console.log("复选框 值: " + wc);

如还有疑问,可以私信帮助解决。

非常感谢,成功 解决此问题了。

  • 这篇文章讲的很详细,请看:layui复选框无法选中问题解决
  • 除此之外, 这篇博客: layui框架中的 表单 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 效果如图
    在这里插入图片描述
    定义表格

    <table class="layui-hide" id="test" lay-filter="test"></table>
    

    头部工具栏

    <script type="text/html" id="toolbarDemo">
      <div class="layui-btn-container">
        <button class="layui-btn layui-btn-sm" lay-event="getCheckData">获取选中行数据</button>
        <button class="layui-btn layui-btn-sm" lay-event="getCheckLength">获取选中数目</button>
        <button class="layui-btn layui-btn-sm" lay-event="isAll">验证是否全选</button>
      </div>
    </script>
    

    表格工具栏

    <script type="text/html" id="barDemo">
      <a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
      <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
    </script>
    

    表格数据获取

    table.render({
        elem: '#test'
        ,url:'/test/table/demo1.json'
        ,toolbar: '#toolbarDemo'
        ,title: '用户数据表'
        ,cols: [[
          {type: 'checkbox', fixed: 'left'}
          ,{field:'id', title:'ID', width:80, fixed: 'left', unresize: true, sort: true}
          ,{field:'username', title:'用户名', width:120, edit: 'text'}
          ,{field:'email', title:'邮箱', width:150, edit: 'text', templet: function(res){
            return '<em>'+ res.email +'</em>'
          }}
          ,{field:'sex', title:'性别', width:80, edit: 'text', sort: true}
          ,{field:'city', title:'城市', width:100}
          ,{field:'sign', title:'签名'}
          ,{field:'experience', title:'积分', width:80, sort: true}
          ,{field:'ip', title:'IP', width:120}
          ,{field:'logins', title:'登入次数', width:100, sort: true}
          ,{field:'joinTime', title:'加入时间', width:120}
          ,{fixed: 'right', title:'操作', toolbar: '#barDemo', width:150}
        ]]
        ,page: true
      });
    

    头部工具栏事件

    table.on('toolbar(test)', function(obj){
        var checkStatus = table.checkStatus(obj.config.id);
        switch(obj.event){
          case 'getCheckData':
            var data = checkStatus.data;
            layer.alert(JSON.stringify(data));
          break;
          case 'getCheckLength':
            var data = checkStatus.data;
            layer.msg('选中了:'+ data.length + ' 个');
          break;
          case 'isAll':
            layer.msg(checkStatus.isAll ? '全选': '未全选');
          break;
        };
      });
    

    表行工具栏事件

    table.on('tool(test)', function(obj){
        var data = obj.data;
        //console.log(obj)
        if(obj.event === 'del'){
          layer.confirm('真的删除行么', function(index){
            obj.del();
            layer.close(index);
          });
        } else if(obj.event === 'edit'){
          layer.prompt({
            formType: 2
            ,value: data.email
          }, function(value, index){
            obj.update({
              email: value
            });
            layer.close(index);
          });
        }
      });
    

    表格重载

    table.reload('test', {
            page: 1 
            ,where: {
            	//需要传递新的属性
              	属性:属性值
              }
          });