it-roy-ru.com

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

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

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

<input type="checkbox" id="ans" value="1" />
565
Rajeev

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

Больше информации здесь.

983
Andy Mikula
$("#ans").attr('checked') 

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

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

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

$("#ans").prop('checked')
206
xaxxon

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

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

88
SimionBaws
// use ternary operators
$("#ans").is(':checked') ? 1 : 0;
54
Stefan Brinkmann

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

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

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

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

20
crashwap

Вы можете попробовать это:

$('#studentTypeCheck').is(":checked");
17
MAnoj Sarnaik

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

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

используйте код для получения значения флажка:

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

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

15
alphakevin
$('input:checkbox:checked').val();        // get the value from a checked checkbox
7
nobody

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

$("#ans:checked").length == 1;
6
Fareed Alnamrouti
<input type="checkbox" id="ans" value="1" />

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

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

$test =($request->get ( 'test' )== "true")? '1' : '0';
6
Rajesh RK

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

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

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

4
Amit Maru
function chkb(bool){
if(bool)
return 1;
return 0;
}

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

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

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

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

var statusNum=chkb($("#ans"));
4
kmoney12

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

$("#ans option:selected").val()
4
Senthil Kumar Bhaskaran

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

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

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

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

3
Robert

Попробуй это

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

Здесь флаг равен true, если установлен флажок, иначе false

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

Опять это сделает чек 

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

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

$("input[type='checkbox']").prop("checked");
$("input[type='checkbox']").is(":checked");
0
PPB

Сначала проверьте значение проверено

$("#ans").find("checkbox").each(function(){
    if ($(this).prop('checked')==true){ 
    var id = $(this).val()
    }
});

В противном случае установите значение 0

0
Ashok Charu

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

$("#ans:checked").length
0
Nasaralla

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

$('input[id=ans]').is(':checked');     
0
swathi
 $("#id").prop('checked') === true ? 1 : 0;
0
Paulo Rodrigues