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);
如还有疑问,可以私信帮助解决。
非常感谢,成功 解决此问题了。
效果如图
定义表格
<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: {
//需要传递新的属性
属性:属性值
}
});