Тестирование, если флажок установлен с помощью jQuery

Если флажок установлен, тогда мне нужно только получить значение как 1; в противном случае мне нужно получить его как 0. Как это сделать с помощью jQuery?

$("#ans").val() всегда даст мне право в этом случае:

<input type="checkbox" id="ans" value="1" />
+529
27 янв. '11 в 5:59
источник поделиться
17 ответов

Используйте .is(':checked'), чтобы определить, проверено ли оно, и затем установите соответствующее значение.

Дополнительная информация здесь

+937
27 янв. '11 в 6:03
источник

Связанные вопросы


Похожие вопросы

$("#ans").attr('checked') 

сообщит, проверен ли он. Вы также можете использовать второй параметр true/false для проверки/снятия флажка.

$("#ans").attr('checked', true);

Для комментариев используйте prop вместо attr, когда это доступно. Например:

$("#ans").prop('checked')
+197
27 янв. '11 в 6:05
источник

Просто используйте $(selector).is(':checked')

Возвращает логическое значение.

+83
09 мая '12 в 11:47
источник
// use ternary operators
$("#ans").is(':checked') ? 1 : 0;
+51
16 апр. '13 в 15:31
источник

Ответ Стефана Бринкмана превосходный, но неполный для новичков (опускает назначение переменной). Просто уточнить:

// this structure is called a ternary operator
var cbAns = ( $("#ans").is(':checked') ) ? 1 : 0;

Он работает следующим образом:

 var myVar = ( if test goes here ) ? 'ans if yes' : 'ans if no' ;

Пример:

var myMath = ( 1 > 2 ) ? 'yes' : 'no' ;
alert( myMath );

Оповещения "нет"

Если это полезно, пожалуйста, подтвердите ответ Стефана Бринкмана.

+18
30 янв. '15 в 16:31
источник

Вы можете попробовать следующее:

$('#studentTypeCheck').is(":checked");
+16
08 авг. '15 в 11:39
источник

Я нашел ту же проблему раньше, надеюсь, что это решение может вам помочь. во-первых, добавьте пользовательский атрибут в свои флажки:

<input type="checkbox" id="ans" value="1" data-unchecked="0" />

напишите расширение jQuery для получения значения:

$.fn.realVal = function(){
    var $obj = $(this);
    var val = $obj.val();
    var type = $obj.attr('type');
    if (type && type==='checkbox') {
        var un_val = $obj.attr('data-unchecked');
        if (typeof un_val==='undefined') un_val = '';
        return $obj.prop('checked') ? val : un_val;
    } else {
        return val;
    }
};

используйте код, чтобы получить значение check-box:

$('#ans').realVal();

вы можете протестировать здесь

+15
05 июл. '12 в 8:22
источник
$('input:checkbox:checked').val();        // get the value from a checked checkbox
+7
28 авг. '13 в 7:42
источник

Вы также можете использовать:

$("#ans:checked").length == 1;
+6
08 авг. '11 в 4:53
источник
<input type="checkbox" id="ans" value="1" />

JQuery: var test= $("#ans").is(':checked') и он возвращает true или false.

В вашей функции:

$test =($request->get ( 'test' )== "true")? '1' : '0';
+6
14 февр. '14 в 4:53
источник
function chkb(bool){
if(bool)
return 1;
return 0;
}

var statusNum=chkb($("#ans").is(':checked'));

statusNum будет равен 1, если флажок установлен, а 0, если это не так.

EDIT: вы также можете добавить DOM к функции.

function chkb(el){
if(el.is(':checked'))
return 1;
return 0;
}

var statusNum=chkb($("#ans"));
+4
17 сент. '12 в 21:45
источник

Использование:

$("#ans option:selected").val()
+4
27 янв. '11 в 6:05
источник

Есть несколько вариантов, например....

 1. $("#ans").is(':checked') 
 2. $("#ans:checked")
 3. $('input:checkbox:checked'); 

Если все эти опции возвращают true, вы можете установить значение accourdingly.

+3
19 сент. '16 в 9:27
источник

Недавно я просмотрел случай, когда мне нужно проверить значение флажка, когда пользователь нажал кнопку. Единственный правильный способ сделать это - использовать атрибут prop().

var ansValue = $("#ans").prop('checked') ? $("#ans").val() : 0;

это сработало в моем случае, может быть, кому-то это понадобится.

Когда я пробовал .attr(':checked'), он возвращал checked, но мне нужно логическое значение и .val() возвращаемое значение атрибута value.

+2
28 янв. '16 в 12:22
источник

попробуйте это

$('input:checkbox:checked').click(function(){
    var val=(this).val(); // it will get value from checked checkbox;
})

Здесь флаг имеет значение true, если отмечено иначе false

var flag=$('#ans').Attr('checked');

Снова это сделает cheked

$('#ans').Attr('checked',true);
+1
22 февр. '13 в 6:58
источник

Если вы хотите, чтобы целое значение проверялось или не пыталось:

$( "# анс: проверено" ). Длина

0
14 нояб. '16 в 12:40
источник

Вы можете получить значение (true/false) этими двумя способами

$("input[type='checkbox']").prop("checked");
$("input[type='checkbox']").is(":checked");
0
15 авг. '16 в 11:31
источник

Посмотрите другие вопросы по меткам или Задайте вопрос