Obtendo todas as caixas de seleção selecionadas em uma matriz

168

Então, eu tenho essas caixas de seleção:

<input type="checkbox" name="type" value="4" />
<input type="checkbox" name="type" value="3" />
<input type="checkbox" name="type" value="1" />
<input type="checkbox" name="type" value="5" />

E assim por diante. Existem cerca de 6 deles e são codificados manualmente (ou seja, não são buscados em um banco de dados), portanto eles provavelmente permanecerão os mesmos por um tempo.

Minha pergunta é como posso obtê-los todos em uma matriz (em javascript), para que eu possa usá-los ao fazer uma $.postsolicitação AJAX usando Jquery.

Alguma ideia?

Editar: eu gostaria apenas que as caixas de seleção selecionadas fossem adicionadas à matriz

Click Voto a favor
fonte
Possível duplicado da série jquery várias caixas de verificação
Jason C
Enquanto a outra pergunta é mais recente e essa é mais popular, a outra tem uma coleção de respostas melhor e mais sucinta (incluindo as estratégias aqui, mais algumas).
Jason C

Respostas:

331

Formatado:

$("input:checkbox[name=type]:checked").each(function(){
    yourArray.push($(this).val());
});

Espero que funcione.

ybo
fonte
1
eo que fazer caixa de seleção desmarque se, para o valor de remoção de gama
Jubin Patel
@JubinPatel, você só precisa redefinir a matriz antes desse código. yourArray = []
RRK
11
Você também pode definir sua matriz imediatamente usando em mapvez de each:var yourArray = $("input:checkbox[name=type]:checked").map(function(){return $(this).val()}).get()
Duvrai
3
function get_selected_checkboxes_array(){ var ch_list=Array(); $("input:checkbox[type=checkbox]:checked").each(function(){ch_list.push($(this).val());}); return ch_list; }
M em
50
var chk_arr =  document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;             

for(k=0;k< chklength;k++)
{
    chk_arr[k].checked = false;
} 
Milind
fonte
6
Pelo que entendi o código acima, ele percorre todas as caixas de seleção e desmarque-as. Como esta resposta está relacionada à pergunta?
Terite 18/08/16
2
Isso simplesmente percorre as caixas de seleção e desmarca-as. Para a resposta correta, no VanillaJS, consulte a resposta de zahid ullah abaixo.
precisa saber é
2
Como isso responde à pergunta? Isso faz algo completamente não relacionado ao que é solicitado. Por que existem tantos votos positivos? Estou faltando alguma coisa ou a pergunta foi editada depois que as pessoas votaram positivamente?
Shubham Chaudhary
46

JS puro

Para quem não quer usar o jQuery

var array = []
var checkboxes = document.querySelectorAll('input[type=checkbox]:checked')

for (var i = 0; i < checkboxes.length; i++) {
  array.push(checkboxes[i].value)
}
Chris Underdown
fonte
5
Sempre ame uma resposta JS baunilha.
Formicini 14/05/19
39

Eu não testei, mas deve funcionar

<script type="text/javascript">
var selected = new Array();

$(document).ready(function() {

  $("input:checkbox[name=type]:checked").each(function() {
       selected.push($(this).val());
  });

});

</script>
Barbaros Alp
fonte
pressione para adicionar valor na matriz, mas o que remover ao desmarcar?
Jubin Patel
24

Isso deve fazer o truque:

$('input:checked');

Não acho que você tenha outros elementos que possam ser verificados, mas, se o fizer, terá que torná-lo mais específico:

$('input:checkbox:checked');

$('input:checkbox').filter(':checked');
Georg Schölly
fonte
14

No MooTools 1.3 (o mais tardar no momento da escrita):

var array = [];
$$("input[type=checkbox]:checked").each(function(i){
    array.push( i.value );
});
LeeGee
fonte
7
Não sabia que a idade da pergunta ou a natureza da solução era relevante.
precisa saber é o seguinte
4
Porque encontrei essa pergunta ao procurar a resposta para o mesmo problema usando o MooTools.
precisa
Observe que esta resposta está relacionada ao MooTools 1.3, não ao jQuery.
precisa
13

Se você deseja usar um JS vanilla, você pode fazê-lo da mesma forma que um @ zahid-ullah, mas evitando um loop:

  var values = [].filter.call(document.getElementsByName('fruits[]'), function(c) {
    return c.checked;
  }).map(function(c) {
    return c.value;
  });

O mesmo código no ES6 parece muito melhor:

var values = [].filter.call(document.getElementsByName('fruits[]'), (c) => c.checked).map(c => c.value);

Terite
fonte
12

Em Javascript, seria assim (Link Demo) :

// get selected checkboxes
function getSelectedChbox(frm) {
  var selchbox = [];// array that will store the value of selected checkboxes
  // gets all the input tags in frm, and their number
  var inpfields = frm.getElementsByTagName('input');
  var nr_inpfields = inpfields.length;
  // traverse the inpfields elements, and adds the value of selected (checked) checkbox in selchbox
  for(var i=0; i<nr_inpfields; i++) {
    if(inpfields[i].type == 'checkbox' && inpfields[i].checked == true) selchbox.push(inpfields[i].value);
  }
  return selchbox;
}   
zahid ullah
fonte
12

Versão ES6:

const values = Array
  .from(document.querySelectorAll('input[type="checkbox"]'))
  .filter((checkbox) => checkbox.checked)
  .map((checkbox) => checkbox.value);

quotesBro
fonte
5

JavaScript puro, sem necessidade de variáveis ​​temporárias:

Array.from(document.querySelectorAll("input[type=checkbox][name=type]:checked")).map(e => e.value)
Wilbert
fonte
solução mais concisa usando baunilha JS
M. Mufti
3
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
        return this.value;
    }).get();
Jean-Marc Amon
fonte
3

Ao marcar, adicione o valor para a caixa de seleção e ao descriptografar, subtraia o valor

$('#myDiv').change(function() {
  var values = 0.00;
  {
    $('#myDiv :checked').each(function() {
      //if(values.indexOf($(this).val()) === -1){
      values=values+parseFloat(($(this).val()));
      // }
    });
    console.log( parseFloat(values));
  }
});
<div id="myDiv">
  <input type="checkbox" name="type" value="4.00" />
  <input type="checkbox" name="type" value="3.75" />
  <input type="checkbox" name="type" value="1.25" />
  <input type="checkbox" name="type" value="5.50" />
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

Joepraveen
fonte
Por favor, adicione um pouco de explicação à sua resposta. Respostas de código puro geralmente não são úteis.
sjaustirni
3

Outra maneira de fazer isso com o vanilla JS nos navegadores modernos (sem suporte ao IE e, infelizmente, sem suporte ao iOS Safari no momento da redação) é com o FormData.getAll () :

var formdata   = new FormData(document.getElementById("myform"));
var allchecked = formdata.getAll("type"); // "type" is the input name in the question

// allchecked is ["1","3","4","5"]  -- if indeed all are checked
foz
fonte
1

Usando Jquery

Você só precisa adicionar classe a cada entrada, eu adiciono classe "source", você pode alterá-lo, é claro

<input class="source" type="checkbox" name="type" value="4" />
<input class="source" type="checkbox" name="type" value="3" />
<input class="source" type="checkbox" name="type" value="1" />
<input class="source" type="checkbox" name="type" value="5" />

<script type="text/javascript">
$(document).ready(function() {
    var selected_value = []; // initialize empty array 
    $(".source:checked").each(function(){
        selected_value.push($(this).val());
    });
    console.log(selected_value); //Press F12 to see all selected values
});
</script>
Ahmed Al Bermawy
fonte
1

Usa isto:

var arr = $('input:checkbox:checked').map(function () {
  return this.value;
}).get();
MHK
fonte
0

Use commented if block para evitar adicionar valores que já estão na matriz se você usar o botão clicar ou algo para executar a inserção

$('#myDiv').change(function() {
  var values = [];
  {
    $('#myDiv :checked').each(function() {
      //if(values.indexOf($(this).val()) === -1){
      values.push($(this).val());
      // }
    });
    console.log(values);
  }
});
<div id="myDiv">
  <input type="checkbox" name="type" value="4" />
  <input type="checkbox" name="type" value="3" />
  <input type="checkbox" name="type" value="1" />
  <input type="checkbox" name="type" value="5" />
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

Nisal Edu
fonte
0

Você pode tentar algo como isto:

$('input[type="checkbox"]').change(function(){
       var checkedValue = $('input:checkbox:checked').map(function(){
                return this.value;
            }).get();         
            alert(checkedValue);   //display selected checkbox value     
 })

Aqui

$('input[type="checkbox"]').change(function() call when any checkbox checked or unchecked, after this
$('input:checkbox:checked').map(function()  looping on all checkbox,
pappu kr Sharma
fonte
0

Aqui está o meu código para o mesmo problema que alguém também pode tentar. jquery

<script>
$(document).ready(function(){`
$(".check11").change(function(){
var favorite1 = [];        
$.each($("input[name='check1']:checked"), function(){                    
favorite1.push($(this).val());
document.getElementById("countch1").innerHTML=favorite1;
});
});
});
</script>
Rahul Gupta
fonte
0

function selectedValues(ele){
  var arr = [];
  for(var i = 0; i < ele.length; i++){
    if(ele[i].type == 'checkbox' && ele[i].checked){
      arr.push(ele[i].value);
    }
  }
  return arr;
}

Kapil
fonte
Para uma resposta útil, essa reação precisa ser estendida. Explique por que essa é uma resposta para a pergunta.
Jeroen Heier
Bem-vindo ao Stack Overflow e obrigado por sua contribuição! Seria bom se você lesse este guia. Como escrever uma boa resposta e ajustá-la de acordo. Obrigado!
David
0
var array = []
    $("input:checkbox[name=type]:checked").each(function(){
        array.push($(this).val());
    });
Salione
fonte