【问题标题】:Trying to toggle checkbox the value of checked property试图切换复选框选中属性的值
【发布时间】:2013-02-26 05:27:40
【问题描述】:

我正在尝试针对具有“复选框”类的各种块,它们都包含一个标签和一个复选框类型的输入。当单击 .checkbox 区域内的任何位置(输入除外)时,“选中”值正在切换,当单击输入时,该值保持不变。有人可以向我解释为什么会这样(为什么单击输入时,值不会切换)?

HTML

<div class="checkbox">
    <label for="a">a</label>
    <input type="checkbox" name="a" checked>
</div>
<div class="checkbox">
    <label for="b">b</label>
    <input type="checkbox" name="b">
</div>

jQuery

​​>
function toggleProp(el) {
    $(el).prop("checked", !el.prop("checked"));
}

$(".checkbox").click(function () {
    toggleProp($(this).find("input"));
});

Live example

编辑:

  • 它应该做什么:

    单击 .checkbox 区域内的任意位置,输入的选中属性的值应该已从 true 切换为 false,反之亦然。

  • 它的作用:

    单击 .checkarea 区域内的任何位置,除了 (!) 输入会切换值。单击输入时,值保持不变,这是不想要的

【问题讨论】:

标签: jquery checkbox


【解决方案1】:

找到了。

我还必须添加这部分:

$(".checkbox input").click(function(e) {
    e.stopPropagation();
});

这样,当点击输入时,不会触发其父级的点击事件

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-03-14
    • 1970-01-01
    • 2018-04-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-01-03
    相关资源
    最近更新 更多