如何将复选框中的值添加到数组中

时间:2011-09-13 10:26:06

标签: javascript arrays forms checkbox

我有一个包含几个复选框的表单。发送此表单后,我需要这些复选框(值)到javascript数组。

有人可以给我一个忙吗,怎么办?

4 个答案:

答案 0 :(得分:3)

var form = document.getElementById("yourformname"),
    inputs = form.getElementsByTagName("input"),
    arr = [];

for (var i = 0, max = inputs.length; i < max; i += 1) {
   // Take only those inputs which are checkbox
   if (inputs[i].type === "checkbox" && inputs[i].checked) {
      arr.push(inputs[i].value);
   }
}

答案 1 :(得分:1)

使用jquery你可以做这样的事情:

var checkboxArr=[];
$('input[type=checkbox]').each(function(){
    checkboxArr.push(this);
});

未经测试且不确定这在纯粹的js中是如何工作的,也许它可以指向正确的方向

答案 2 :(得分:1)

var values = [],
    inputs = document.getElementsByTagName("input");

for (var i = inputs.length -1 ; i>= 0; i--)
    if (inputs[i].type === "checkbox" && inputs[i].checked)
          values.push(inputs[i].value);

表示纯JS。

答案 3 :(得分:0)

您可以在jsfiddle上测试以下功能:

function getCheckboxes(form_id, name) {
    // returns array of checked checkboxes with 'name' in 'form_id'
    var form = document.getElementById(form_id);
    var inputs = form.getElementsByTagName("input");
    var values = [];
    for (var i = 0; i < inputs.length; ++i) {
        if (inputs[i].type === "checkbox" && 
            inputs[i].name === name &&
            inputs[i].checked) 
        {
            values.push(inputs[i].value);
        }
    }
    return values;
}