ChatGPT解决这个技术问题 Extra ChatGPT

在jQuery中获取复选框值

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


N
Nagama Inamdar

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

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

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

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

但是,无论是否选中,这都会返回相同的值,这可能会令人困惑,因为它与提交的表单行为不同。

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

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

如果我在 Chrome 中尝试 $($0).val() 并取消选中复选框,即使未选中,答案也是“打开”。但 $($0).is(":checked") 返回正确的值。
赞成错误的答案。意识到它确实 on 总是晚一点
抱歉,但这个答案实际上浪费了我大约 1 个小时的时间。使用 .val(); 时,所有复选框都“打开” 我强烈建议任何阅读本文的人使用 .is(":checked")
A
Alain Tiemblo

这两种方法有效:

$('#checkbox').prop('选中')

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

$('#test').click(function() { alert("复选框状态(方法一) = " + $('#test').prop('checked')); alert("复选框状态(方法二) = " + $('#test').is(':checked')); }); 检查我:


R
RDK

试试这个小解决方案:

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

或者

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

或者 !!($("#some_id").attr("checked"))
R
Reza

检索复选框值的最佳方法如下

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

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

当您拥有该元素并且您知道它是一个复选框时,您可以简单地读取它的属性并且您不需要 jQuery(即 elem.checked)或者您可以使用 $(elem).prop("checked") 如果您想依赖jQuery。

如果您需要知道(或比较)元素首次加载时的值(即默认值),正确的方法是 elem.getAttribute("checked") 或 elem.prop("defaultChecked")。

请注意,elem.attr("checked") 仅在 jQuery 1.6.1+ 版本之后被修改,以返回与 elem.prop("checked") 相同的结果。

有些答案具有误导性或不准确,请自行检查以下内容:

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


.is(":checked").prop(":checked") 对我来说与 jQuery 1.10.0 相同
@Josh,你说得对,谢谢!我更新了答案以澄清未来的读者。
G
Greg A

只是为了澄清一些事情:

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

将返回“真”或“假”


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

不起作用。在检查 ':checked' 之前你可能需要一列
.val() 不起作用。无论是否选中,都返回“on”。
$('#checkbox_id').is(":checked"); 返回一个布尔值,正是我所需要的。
K
Kevin Shea

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

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

提供 true/false


K
Kamal
//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


J
Jaskaran singh Rajal
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);
    });

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

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


这也适用于我的情况。谢谢
J
Josh Crozier

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

没有 jQuery:

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

var checkbox = document.querySelector('input[type="checkbox"]');警报(复选框。选中);

下面是一个监听 change 事件的简单示例:

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

要选择选中的元素,请使用 :checked pseudo class (input[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);


F
Faraz Kelhini

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

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

S
Sudhir Ojha

使用以下代码:

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

t
ttrasn

获取 jquery 中已选中复选框的值:

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
});

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

问题是询问如何获取值而不是如何检查具有特定默认值的内容。
H
Hayrullah Cansu

最好的方法是$('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>

T
Tahir Afridi

对于超过 1 个复选框,请始终使用命名数组,如下面的国家/地区示例所示,因为您知道可以选择多个国家/地区,因此我使用 name="countries[]" 并且在检查复选框时,您必须按名称引用它,如所示下面的例子

var selectedCountries = ["巴基斯坦", "美国"]; $(document).ready(function () { $.each(selectedCountries, function (index, country) { $(`input[name='countries[]'][value='${country}']`)。 attr('checked', 'checked'); }); });

巴基斯坦

印度

美国


K
Kuldeep Mishra
<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>

h
hoogw

请注意,截至今天,2018 年,由于多年来 API 的变化。 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);