Como posso obter o valor de uma caixa de seleção no jQuery?
534
Para obter o valor do atributo Value, você pode fazer algo assim:
$("input[type='checkbox']").val();
Ou, se você definiu um class
ou id
para ele, pode:
$('#check_id').val();
$('.check_class').val();
No entanto, isso retornará o mesmo valor, verificado ou não, isso pode ser confuso, pois é diferente do comportamento do formulário enviado.
Para verificar se está marcado ou não, faça:
if ($('#check_id').is(":checked"))
{
// it is checked
}
$("input:checkbox")
. Além disso, parece haver um erro de digitação no seletor de classe ...$($0).val()
no Chrome e desmarcar a caixa de seleção, a resposta será "ativada", mesmo que não esteja marcada. Mas$($0).is(":checked")
retorna o valor certo.[type="checkbox"]
tem melhor desempenho em navegadores modernos do que:checkbox
.$('#check_id').val();
para$('#check_id').is(":checked");
retornar o valor verdadeiro ou falso.Essas duas maneiras estão funcionando:
$('#checkbox').prop('checked')
$('#checkbox').is(':checked')
(obrigado @mgsloan)fonte
Experimente esta pequena solução:
ou
fonte
As únicas maneiras corretas de recuperar o valor de uma caixa de seleção são as seguintes
conforme explicado nas documentações oficiais no site do jQuery. O restante dos métodos não tem nada a ver com a propriedade da caixa de seleção, eles estão verificando o atributo, o que significa que estão testando o estado inicial da caixa de seleção quando ela foi carregada. Então, resumindo:
elem.checked
) ou poderá usá-$(elem).prop("checked")
lo se quiser confiar no jQuery.$(elem).is(":checked")
.As respostas são enganosas, verifique abaixo você mesmo:
http://api.jquery.com/prop/
fonte
.is(":checked")
e.prop(":checked")
estão trabalhando o mesmo para mim w / jQuery 1.10.0Apenas para esclarecer as coisas:
Retornará 'verdadeiro' ou 'falso'
fonte
fonte
fonte
Simples, mas eficaz e pressupõe que você saiba que a caixa de seleção será encontrada:
Dá
true
/false
fonte
Demonstração de exemplo
fonte
Apesar de esta pergunta estar pedindo uma solução jQuery, aqui está uma resposta JavaScript pura, já que ninguém a mencionou.
Sem jQuery:
Basta selecionar o elemento e acessar a
checked
propriedade (que retorna um booleano).Aqui está um exemplo rápido ao ouvir o
change
evento:Para selecionar elementos marcados, use a
:checked
pseudo classe (input[type="checkbox"]:checked
).Aqui está um exemplo que itera sobre os
input
elementos verificados e retorna uma matriz mapeada dos nomes dos elementos verificados.Exemplo Aqui
Mostrar snippet de código
fonte
checked
propriedade é facilmente acessível no elemento DOM nativo. Algumas pessoas que pesquisam perguntas / respostas como essas geralmente desconhecem o fato de que o jQuery às vezes não é necessário. Em outras palavras, as pessoas de mente estreita não são o alvo demográfico para esta resposta.Aqui está como obter o valor de todas as caixas de seleção marcadas como uma matriz:
fonte
para obter o valor do checkboxex marcado em
jquery
:em
pure js
:fonte
Use o seguinte código:
fonte
fonte
A melhor maneira é
$('input[name="line"]:checked').val()
E também você pode obter o texto selecionado
$('input[name="line"]:checked').text()
Inclua atributo e nome de valor nas entradas do botão de opção. Certifique-se de que todas as entradas tenham o mesmo atributo de nome.
fonte
fonte
Apenas atenção, a partir de hoje, 2018, devido à mudança de APIs ao longo dos anos. removeAttr está obsoleto, NÃO está mais funcionando!
Jquery Marque ou desmarque uma caixa de seleção:
Ruim, não funciona mais.
Em vez disso, você deve fazer:
fonte