我可以使用 jQuery 检查是否至少选中了一个复选框?

IT技术 javascript jquery
2021-02-24 21:30:30

我有以下 HTML 表单,其中可以有许多复选框。单击提交按钮时,如果没有选中任何复选框,我希望用户收到一个 javascript 警报以检查至少一个复选框。有没有一种简单的方法可以使用 jQuery 做到这一点?

<form name = "frmTest" id="frmTest">
  <input type="checkbox" value="true" checked="true" name="chk[120]">
  <input type="checkbox" value="true" checked="true" name="chk[128]">
  <input type="checkbox" name="chk[130]">
  <input type="checkbox" name="chk[143]">
  <input type="submit" name="btnsubmit" value="Submit">
</form>
6个回答
if(jQuery('#frmTest input[type=checkbox]:checked').length) { … }
@Jan —jQuery('#frmTest input[type=checkbox]:checked')返回一个包含与选择器匹配的所有元素的 jQuery 对象。它不返回布尔值。您可能会将它与HTMLInputElement.checked.
2021-05-07 21:30:30
:checked 已经返回一个布尔值,所以不需要 .length。true.length 和 false.length 都提供 undefined
2021-05-20 21:30:30
$('#frmTest input:checked').length > 0
@David,我已删除该建议。
2021-04-27 21:30:30
为什么单选按钮会更好?如果 OP需要至少一个选项,则选择的单选按钮会将他限制为最多一个
2021-05-03 21:30:30
$('#frmTest:checkbox').length > 0 最好在一定数量的复选框中进行检查。
2021-05-05 21:30:30
$("#frmTest").submit(function(){
    var checked = $("#frmText input:checked").length > 0;
    if (!checked){
        alert("Please check at least one checkbox");
        return false;
    }
});
$("#show").click(function() {
    var count_checked = $("[name='chk[]']:checked").length; // count the checked rows
        if(count_checked == 0) 
        {
            alert("Please select any record to delete.");
            return false;
        }
        if(count_checked == 1) {
            alert("Record Selected:"+count_checked);

        } else {
            alert("Record Selected:"+count_checked);
          }
});
对我不起作用,jQuery 处理复选框选中事件的方式发生了一些变化?
2021-04-26 21:30:30

$('#fm_submit').submit(function(e){
    e.preventDefault();
    var ck_box = $('input[type="checkbox"]:checked').length;
    
    // return in firefox or chrome console 
    // the number of checkbox checked
    console.log(ck_box); 

    if(ck_box > 0){
      alert(ck_box);
    } 
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form name = "frmTest[]" id="fm_submit">
  <input type="checkbox" value="true" checked="true" >
  <input type="checkbox" value="true" checked="true" >
  <input type="checkbox" >
  <input type="checkbox" >
  <input type="submit" id="fm_submit" name="fm_submit" value="Submit">
</form>
<div class="container"></div>