jQuery不会检查复选框

Adr*_*ian 7 checkbox jquery

我需要帮助自动检查树视图中的复选框.

我有一个树视图,当我单击复选框时,列表中的所有子项将自动选中其复选框.问题是它不起作用.

treeview.find('input[type=checkbox]').each(function () {
    $j(this).click(function () {
        if ($j(this).is(':checked')) {
            $j(this).siblings('ul').find('input[type=checkbox]').attr('checked', 'checked');
        } else {
            $j(this).siblings('ul').find('input[type=checkbox]').removeAttr('checked');
        }
    });
});
Run Code Online (Sandbox Code Playgroud)

所以代码说明了一切,我找到所有的复选框,并在每个我绑定点击事件.单击该项目时,它会检查是否已选中,然后查找所有复选框并将其属性设置为选中,否则查找所有复选框并删除其已选中的属性.我的选择器工作正常,所以这不是问题.

当我点击一个复选框时,会检查所有复选框,当我取消选中时,它仍然有效.但是在另一次尝试中,它不再起作用了!这很奇怪!最奇怪的是,当我检查代码时,我可以在复选框上看到它有checked="checked"但浏览器不会呈现已检查状态(实际上这是主要问题).

spu*_*dly 14

使用:

$el.prop('checked', true) // to check the box
$el.prop('checked', false) // to uncheck the box
Run Code Online (Sandbox Code Playgroud)

代替:

$el.attr('checked', 'checked') // to check the box
$el.removeAttr('checked') // to uncheck the box
Run Code Online (Sandbox Code Playgroud)

这是因为您需要更改框的已检查状态,而不是已更改的属性.checked属性仅用于复选框的初始状态.