获取jQuery中的复选框值

时间:2010-05-14 13:08:47

标签: jquery html forms checkbox

如何在jQuery中获取复选框的值?

18 个答案:

答案 0 :(得分:865)

要获取Value属性的值,您可以执行以下操作:

$("input[type='checkbox']").val();

或者,如果您为其设置了classid,则可以:

$('#check_id').val();
$('.check_class').val();

然而,无论是否检查,都会返回相同的值,这可能会造成混淆,因为它与提交的表单行为不同。

要检查是否已选中,请执行以下操作:

if ($('#check_id').is(":checked"))
{
  // it is checked
}

答案 1 :(得分:187)

这两种方式正在发挥作用:

  • $('#checkbox').prop('checked')
  • $('#checkbox').is(':checked')(谢谢 @mgsloan

$('#test').click(function() {
    alert("Checkbox state (method 1) = " + $('#test').prop('checked'));
    alert("Checkbox state (method 2) = " + $('#test').is(':checked'));
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
Check me: <input id="test" type="checkbox" />

答案 2 :(得分:55)

尝试这个小解决方案:

$("#some_id").attr("checked") ? 1 : 0;

$("#some_id").attr("checked") || 0;

答案 3 :(得分:28)

检索复选框值的唯一正确方法如下

if ( elem.checked ) 
if ( $( elem ).prop( "checked" ) ) 
if ( $( elem ).is( ":checked" ) ) 

正如jQuery网站上的官方文档中所解释的那样。其余的方法与复选框的属性无关,他们正在检查属性,这意味着他们正在测试加载时复选框的初始状态。简而言之:

  • 如果你有元素并且你知道它是一个复选框,你可以简单地读取它的属性,你不需要jQuery(即elem.checked),或者如果你想要你可以使用$(elem).prop("checked")依靠jQuery。
  • 如果您需要知道(或比较)元素首次加载时的值(即默认值),正确的方法是$(elem).is(":checked")

答案有误导性,请自行检查:

http://api.jquery.com/prop/

答案 4 :(得分:14)

只是为了澄清事情:

$('#checkbox_ID').is(":checked")

将返回'true'或'false'

答案 5 :(得分:11)

$('#checkbox_id').val();
$('#checkbox_id').is(":checked");
$('#checkbox_id:checked').val();

答案 6 :(得分:10)

jQuery(".checkboxClass").click(function(){
        var selectedCountry = new Array();
        var n = jQuery(".checkboxClass:checked").length;
        if (n > 0){
            jQuery(".checkboxClass:checked").each(function(){
                selectedCountry.push($(this).val());
            });
        }
        alert(selectedCountry);
    });

答案 7 :(得分:7)

简单但有效,并假设您知道将找到该复选框:

$("#some_id")[0].checked;

提供true / false

答案 8 :(得分:6)

//By each()
var testval = [];
 $('.hobbies_class:checked').each(function() {
   testval.push($(this).val());
 });


//by map()
var testval = $('input:checkbox:checked.hobbies_class').map(function(){
return this.value; }).get().join(",");

 //HTML Code

 <input type="checkbox" value="cricket" name="hobbies[]"  class="hobbies_class">Cricket 
  <input type="checkbox" value="hockey" name="hobbies[]" class="hobbies_class">Hockey

实施例
   Demo

答案 9 :(得分:6)

尽管这个问题是要求jQuery解决方案,但这是一个纯粹的JavaScript答案,因为没有人提到它。

没有jQuery:

只需选择元素并访问checked property(返回布尔值)。

var checkbox = document.querySelector('input[type="checkbox"]');

alert(checkbox.checked);
<input type="checkbox"/>


以下是聆听change事件的快速示例:

var checkbox = document.querySelector('input[type="checkbox"]');
checkbox.addEventListener('change', function (e) {
    alert(this.checked);
});
<input type="checkbox"/>


要选中选中的元素,请使用:checked pseudo classinput[type="checkbox"]:checked)。

这是一个迭代已检查input元素并返回已检查元素名称的映射数组的示例。

Example Here

var elements = document.querySelectorAll('input[type="checkbox"]:checked');
var checkedElements = Array.prototype.map.call(elements, function (el, i) {
    return el.name;
});

console.log(checkedElements);

var elements = document.querySelectorAll('input[type="checkbox"]:checked');
var checkedElements = Array.prototype.map.call(elements, function (el, i) {
    return el.name;
});

console.log(checkedElements);
<div class="parent">
    <input type="checkbox" name="name1" />
    <input type="checkbox" name="name2" />
    <input type="checkbox" name="name3" checked="checked" />
    <input type="checkbox" name="name4" checked="checked" />
    <input type="checkbox" name="name5" />
</div>

答案 10 :(得分:2)

以下是如何将所有已选中复选框的值作为数组:

var values = (function() {
                var a = [];
                $(".checkboxes:checked").each(function() {
                    a.push(this.value);
                });
                return a;
            })()

答案 11 :(得分:1)

使用以下代码:

$('input[name^=CheckBoxInput]').val();

答案 12 :(得分:1)

$('.class[value=3]').prop('checked', true);

答案 13 :(得分:1)

获取jquery中选中的checkboxex的值:

var checks = $("input[type='checkbox']:checked"); // returns object of checkeds.

for(var i=0; i<checks.length; i++){
    console.log($(checks[i]).val()); // or do what you want
});

pure js中:

var checks = document.querySelectorAll("input[type='checkbox']:checked");

for(var i=0; i<checks.length; i++){
    console.log(checks[i].value); // or do what you want
});

答案 14 :(得分:0)

<script type="text/javascript">
$(document).ready(function(){
    $('.laravel').click(function(){
        var val = $(this).is(":checked");
        $('#category').submit();
    });
});

<form action="{{route('directory')}}" method="post" id="category">
                        <input type="hidden" name="_token" value="{{ csrf_token() }}">
                        <input name="category" value="{{$name->id}}"  class="laravel" type="checkbox">{{$name->name}}
                      </form>

答案 15 :(得分:0)

由于多年以来api的变化,请注意,截至2018年今天。 removeAttr已被删除,无法再使用!

jQuery选中或取消选中复选框:

坏,不再工作了。

   $('#add_user_certificate_checkbox').removeAttr("checked");

   $('#add_user_certificate_checkbox').attr("checked","checked");

相反,您应该这样做:

      $('#add_user_certificate_checkbox').prop('checked', true);
      $('#add_user_certificate_checkbox').prop('checked', false);

答案 16 :(得分:0)

最好的方法是$('input[name="line"]:checked').val()

您还可以获得选定的文本$('input[name="line"]:checked').text()

为单选按钮输入添加值属性和名称。确保所有输入都具有相同的名称属性。

<div class="col-8 m-radio-inline">
    <label class="m-radio m-radio-filter">
        <input type="radio" name="line" value="1" checked> Value Text 1
    </label>
    <label class="m-radio m-radio-filter">
        <input type="radio" name="line" value="2"> Value Text 2
    </label>
    <label class="m-radio m-radio-filter">
        <input type="radio" name="line" value="3"> Value Text 3
    </label>
</div>

答案 17 :(得分:0)

$("input[name='gender']:checked").val();

这在我的情况下有效,任何寻找简单方法的人都必须尝试这种语法。 谢谢