如何防止使用jquery取消选中所有复选框?

时间:2017-02-02 11:26:30

标签: javascript jquery html checkbox checked

我有自定义复选框:

<p>
    <input class="preventUncheck" id="toggle-on1" type="checkbox">
    <label for="toggle-on1">Selling</label>
</p>
<p>
    <input class="preventUncheck" id="toggle-on2" type="checkbox">           
    <label for="toggle-on2">Rent</label> 
</p>
$(function() {
    //prevent to uncheck all checkboxes
    $('.preventUncheck').on('change', function() {
        $('.preventUncheck').length == 0
        && !this.checked
        && $(this).prop('checked', true);
    });
});

我想阻止取消选中所有复选框,这意味着应该检查一个复选框,如果用户尝试取消选中它,javascript会阻止这样做。

我该怎么做才能做到这一点?

2 个答案:

答案 0 :(得分:4)

您应该检查已选中复选框的长度是否等于0,然后阻止取消选中它。

$('.preventUncheck').on('change', function(e) {
    if ($('.preventUncheck:checked').length == 0 && !this.checked)
    	this.checked = true;
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<p>
  <input type="checkbox" class="preventUncheck" id="toggle-on1">
  <label for="toggle-on1">Selling</label>
</p>
<p>
  <input type="checkbox" class="preventUncheck" id="toggle-on2">
  <label for="toggle-on2">Rent</label> 
</p>

答案 1 :(得分:0)

添加attr&#34;禁用&#34;到复选框?