获取数组中所有选定的复选框


168

所以我有这些复选框:

<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" />

等等。它们大约有6个,并且都是手工编码的(即未从数据库中获取),因此它们可能会保持一段时间不变。

我的问题是如何将它们全部放入一个数组中(在javascript中),以便在$.post使用Jquery 进行AJAX 请求时可以使用它们。

有什么想法吗?

编辑:我只希望将选中的复选框添加到数组



虽然另一个问题比较新,并且这个问题更受欢迎,但另一个问题的答案更好,更简洁(包括此处的策略以及一些答案)。
Jason C

Answers:


331

格式化:

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

希望它会起作用。


1
以及取消选中复选框以从数组中删除值时该怎么做
Jubin Patel 2013年

@JubinPatel您只需要在此代码之前重置阵列即可。yourArray = []
RRK 2015年

11
您还可以使用map而不是立即定义数组eachvar yourArray = $("input:checkbox[name=type]:checked").map(function(){return $(this).val()}).get()
Duvrai 2015年

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在

50
var chk_arr =  document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;             

for(k=0;k< chklength;k++)
{
    chk_arr[k].checked = false;
} 

6
据我了解上述代码,它会遍历所有复选框,然后取消选中它们。这个答案与问题如何联系?
Terite

2
这只是在复选框之间循环并取消选中它们。对于正确的答案,在VanillaJS中,请参见下面的zahid ullah答案。
jmknoll '16

2
这如何回答这个问题?这所做的事情与所要求的完全无关。为什么会有这么多投票?我是否缺少某些内容,还是在人们投票赞成后对问题进行了编辑?
Shubham Chaudhary

46

纯JS

对于那些不想使用jQuery的人

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

for (var i = 0; i < checkboxes.length; i++) {
  array.push(checkboxes[i].value)
}

5
永远喜欢香草JS答案。
formicini

39

我没有测试,但应该可以

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

$(document).ready(function() {

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

});

</script>

推动在数组中增加价值,但取消选中要删除什么?
Jubin Patel 2013年

24

这应该可以解决问题:

$('input:checked');

我认为您没有其他可以检查的元素,但是如果要检查,则必须使其更加具体:

$('input:checkbox:checked');

$('input:checkbox').filter(':checked');

14

在MooTools 1.3中(撰写本文时为最新):

var array = [];
$$("input[type=checkbox]:checked").each(function(i){
    array.push( i.value );
});

7
没有意识到问题的年龄或解决方案的性质是相关的。
LeeGee 2011年

4
因为我在使用MooTools寻找相同问题的答案时发现了这个问题。
LeeGee 2012年

请注意,此答案与MooTools 1.3(而非jQuery)有关。
LeeGee

13

如果您想使用普通JS,则可以类似于@ zahid-ullah来完成,但要避免循环:

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

ES6中的相同代码看起来更好:

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


12

在Javascript中,就像这样(演示链接)

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

12

ES6版本:

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


5

纯JavaScript,不需要临时变量:

Array.from(document.querySelectorAll("input[type=checkbox][name=type]:checked")).map(e => e.value)

最简洁的解决方案,使用香草JS
M. Mufti,

3
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
        return this.value;
    }).get();

3

选中时,请添加复选框的值;取消选中时,请减去该值

$('#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>


请在回答中添加一些解释。纯粹的代码答案通常没有用。
sjaustirni

3

在现代浏览器中使用香草JS的另一种方法(不提供IE支持,可惜在撰写本文时不提供iOS Safari支持)是使用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

1

使用jQuery

您只需要向每个输入添加类,我就可以添加类“源”,您当然可以更改它

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

1

用这个:

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

0

如果使用按钮单击或运行插入操作,请使用带注释的if块以防止添加已经在数组中的值

$('#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>


0

您可以尝试这样的事情:

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

这里

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

0

这是我针对相同问题的代码,也可以尝试一下。 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>

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


为了获得有用的答案,需要扩展此反应。解释为什么这是问题的答案。
Jeroen Heier

欢迎使用Stack Overflow,感谢您的贡献!如果您阅读本指南,将是一个很好的方法。如何编写一个好的答案并相应地调整您的答案。谢谢!
大卫,

0
var array = []
    $("input:checkbox[name=type]:checked").each(function(){
        array.push($(this).val());
    });
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.