it-swarm.com.ru

Как проверить переключатель с помощью jQuery?

Я пытаюсь проверить переключатель с помощью jQuery. Вот мой код:

<form>
    <div id='type'>
        <input type='radio' id='radio_1' name='type' value='1' />
        <input type='radio' id='radio_2' name='type' value='2' />
        <input type='radio' id='radio_3' name='type' value='3' /> 
    </div>
</form>

И JavaScript: 

jQuery("#radio_1").attr('checked', true);

Не работает:

jQuery("input[value='1']").attr('checked', true);

Не работает:

jQuery('input:radio[name="type"]').filter('[value="1"]').attr('checked', true);

Не работает:

У тебя есть другая идея? Что мне не хватает?

782
Alexis

Для версий jQuery, равных или выше (> =) 1.6, используйте:

$("#radio_1").prop("checked", true);

Для версий до (<) 1.6 используйте:

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

Совет: После этого вы также можете вызвать click() или change(). Смотрите комментарии для получения дополнительной информации.

1324
Mike Thomsen

Попробуй это.

В этом примере я нацеливаю его на его входное имя и значение

$("input[name=background][value='some value']").prop("checked",true);

Полезно знать: в случае значения нескольких слов, это будет работать и из-за апострофов.

216
Vladimir Djuricic

Еще одна функция prop (), которая добавлена ​​в jQuery 1.6, служит той же цели.

$("#radio_1").prop("checked", true); 
93
Umesh Patil

Краткий и удобный для чтения вариант:

$("#radio_1").is(":checked")

Он возвращает истину или ложь, так что вы можете использовать его в выражении «если».

75
Karbaman

Попробуй это.

Для проверки переключателя используйтезначениеиспользуйте это.

$('input[name=type][value=2]').attr('checked', true); 

Или же

$('input[name=type][value=2]').attr('checked', 'checked');

Или же

$('input[name=type][value=2]').prop('checked', 'checked');

Для проверки переключателя используйтеIDиспользуйте это.

$('#radio_1').attr('checked','checked');

Или же

$('#radio_1').prop('checked','checked');
28
Lakshmana Kumar

Способ $.prop лучше:

$(document).ready(function () {                            
    $("#radio_1").prop('checked', true);        
});

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

$(document).ready(function () {                            
    $("#radio_1, #radio_2", "#radio_3").change(function () {
        if ($("#radio_1").is(":checked")) {
            $('#div1').show();
        }
        else if ($("#radio_2").is(":checked")) {
            $('#div2').show();
        }
        else 
            $('#div3').show();
    });        
});
12
Amin Saqi

Попробуй это:

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

http://jsfiddle.net/nwo706xw/

9
user4457035

Ты должен сделать 

jQuery("#radio_1").attr('checked', 'checked');

Это атрибут HTML

8
JohnP

Да, у меня получилось так:

$("#radio_1").attr('checked', 'checked');
5
Anjan Kant

Если свойство name не работает, не забудьте, что id все еще существует. Этот ответ предназначен для людей, которые хотят настроить таргетинг id здесь, как вы.

$('input[id=element_id][value=element_value]').prop("checked",true);

Потому что свойство name у меня не работает. Убедитесь, что вы не окружаете id и name двойными/одинарными кавычками.

Ура!

5
Anjana Silva

Мы должны сказать, что это кнопка radio. Пожалуйста, попробуйте следующий код.

$("input[type='radio'][name='userRadionButtonName']").prop('checked', true);
4
UWU_SANDUN

На всякий случай, если кто-то пытается достичь этого, используя jQuery UI, вам также необходимо обновить объект флажка UI, чтобы отразить обновленное значение:

$("#option2").prop("checked", true); // Check id option2
$("input[name='radio_options']").button("refresh"); // Refresh button set
4
freeworlder
$("input[name=inputname]:radio").click(function() {
    if($(this).attr("value")=="yes") {
        $(".inputclassname").show();
    }
    if($(this).attr("value")=="no") {
        $(".inputclassname").hide();
    }
});
4
Eray

Попробуй это

var isChecked = $("#radio_1")[0].checked;
3
user2190046

Попробуйте это с примером

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form id="myForm">
<input type="radio" name="radio" value="first"/> 1 <br/>
<input type="radio" name="radio" value="second"/> 2 <br/>
</form>


<script>
$(document).ready(function () {
    $('#myForm').on('click', function () {
        var value = $("[name=radio]:checked").val();

        alert(value);
    })
});
</script>
3
saroj

Получить значение:

$("[name='type'][checked]").attr("value");

Установить значение: 

$(this).attr({"checked":true}).prop({"checked":true});

Радиокнопка нажмите добавить атрибут проверено:

$("[name='type']").click(function(){
  $("[name='type']").removeAttr("checked");
  $(this).attr({"checked":true}).prop({"checked":true});
});
3
Naim Serin

Попробуй это

$(document).ready(function(){
    $("input[name='type']:radio").change(function(){
        if($(this).val() == '1')
        {
          // do something
        }
        else if($(this).val() == '2')
        {
          // do something
        }
        else if($(this).val() == '3')
        {
          // do something
        }
    });
});
2
Jordan Jelinek

У меня есть некоторый связанный пример, который должен быть улучшен, например, если я хочу добавить новое условие, скажем, если я хочу, чтобы цветовая схема была скрыта после того, как я щелкнул по значению статуса проекта, за исключением Pavers и Paving Slabs.

Пример здесь:

$(function () {
    $('#CostAnalysis input[type=radio]').click(function () {
        var value = $(this).val();

        if (value == "Supply & Lay") {
            $('#ul-suplay').empty();
            $('#ul-suplay').append('<fieldset data-role="controlgroup"> \

http://jsfiddle.net/m7hg2p94/4/

2
azim hamdan

Я использую этот код:

Я извиняюсь за английский.

var $j = jQuery.noConflict();

$j(function() {
    // add handler
    $j('#radio-1, #radio-2').click(function(){

        // find all checked and cancel checked
        $j('input:radio:checked').prop('checked', false);

        // this radio add cheked
        $j(this).prop('checked', true);
    });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<fieldset class="section">
  <legend>Radio buttons</legend>
  <label>
    <input type="radio" id="radio-1" checked>
    Option one is this and that&mdash;be sure to include why it's great
  </label>
  <br>
  <label>
    <input type="radio" id="radio-2">
    Option two can be something else
  </label>
</fieldset>

2
volitilov
function rbcitiSelction(e) {
     debugger
    $('#trpersonalemail').hide();
    $('#trcitiemail').show();
}

function rbpersSelction(e) {
    var personalEmail = $(e).val();
    $('#trpersonalemail').show();
    $('#trcitiemail').hide();
}

$(function() {  
    $("#citiEmail").prop("checked", true)
});
1
MadhaviLatha Bathini

Несколько раз вышеуказанные решения не работают, тогда вы можете попробовать ниже:

jQuery.uniform.update(jQuery("#yourElementID").attr('checked',true));
jQuery.uniform.update(jQuery("#yourElementID").attr('checked',false));

Другой способ, которым вы можете попробовать это:

jQuery("input:radio[name=yourElementName]:nth(0)").attr('checked',true);
1
Pankaj Bhagwat

У меня просто есть похожая проблема, простое решение - просто использовать:

.click()

Любое другое решение будет работать, если вы обновите радио после вызова функции.

1
user3148673

попробуй это 

 $("input:checked", "#radioButton").val()

если проверено, возвращает True если не проверено, возвращает False

jQuery v1.10.1
1
pst

Если вы не хотите включать такую ​​простую библиотеку, как jQuery, вот альтернативное решение, использующее встроенные методы DOM:

// Check checkbox by id:
document.querySelector('#radio_1').checked = true;

// Check checkbox by value:
document.querySelector('#type > [value="1"]').checked = true;

// If this is the only input with a value of 1 on the page, you can leave out the #type >
document.querySelector('[value="1"]').checked = true;
<form>
    <div id='type'>
        <input type='radio' id='radio_1' name='type' value='1' />
        <input type='radio' id='radio_2' name='type' value='2' />
        <input type='radio' id='radio_3' name='type' value='3' /> 
    </div>
</form>
0
CertainPerformance

Кроме того, вы можете проверить, проверен ли элемент или нет:

if ($('.myCheckbox').attr('checked'))
{
   //do others stuff
}
else
{
   //do others stuff
}

Вы можете проверить на непроверенный элемент:

$('.myCheckbox').attr('checked',true) //Standards way

Вы также можете снять этот флажок:

$('.myCheckbox').removeAttr('checked')

Вы можете проверить радио кнопку:

Для версий jQuery, равных или выше (> =) 1.6, используйте:

$("#radio_1").prop("checked", true);

Для версий до (<) 1.6 используйте:

$("#radio_1").attr('checked', 'checked');
0
Majedur Rahaman

attr принимает две строки.

Правильный путь:

jQuery("#radio_1").attr('checked', 'true');
0
Iuri Matos

Попробуй это:

$(document).ready(function(){
  $("#Id").prop("checked", true).checkboxradio('refresh');
});
0
user3721473
$("#radio_1").attr('checked', true);
//or
$("#radio_1").attr('checked', 'checked');
0
dominicbri7

Удивительно, но самый популярный и принятый ответ игнорирует запуск соответствующего события, несмотря на комментарии. Убедитесь, что вы вызываете .change(), иначе все привязки «при изменении» будут игнорировать это событие.

$("#radio_1").prop("checked", true).change();
0
apatsekin

attr принимает две строки.

Правильный путь:

jQuery("#radio_1").attr('checked', 'true');
0
Koko Monsef