Получение всех выбранных флажков в массиве - PullRequest
144 голосов
/ 26 февраля 2009

Итак, у меня есть эти флажки:

<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), чтобы я мог использовать их при выполнении запроса AJAX $.post с использованием Jquery.

Есть мысли?

Редактировать: я бы хотел, чтобы только выбранные флажки были добавлены в массив

Ответы [ 17 ]

287 голосов
/ 26 февраля 2009

Отформатировано:

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

Надеюсь, это сработает.

55 голосов
/ 02 марта 2012
var chk_arr =  document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;             

for(k=0;k< chklength;k++)
{
    chk_arr[k].checked = false;
} 
36 голосов
/ 26 февраля 2009

Я не тестировал его, но он должен работать

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

$(document).ready(function() {

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

});

</script>
23 голосов
/ 26 февраля 2009

Это должно сработать:

$('input:checked');

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

$('input:checkbox:checked');

$('input:checkbox').filter(':checked');
22 голосов
/ 02 сентября 2017

Чистый 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)
}
14 голосов
/ 26 июня 2011

В MooTools 1.3 (последний на момент написания):

var array = [];
$$("input[type=checkbox]:checked").each(function(i){
    array.push( i.value );
});
12 голосов
/ 10 мая 2015

В 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;
}   
10 голосов
/ 18 августа 2016

Если вы хотите использовать ванильный 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);

window.serialize = function serialize() {
  var values = [].filter.call(document.getElementsByName('fruits[]'), function(c) {
    return c.checked;
  }).map(function(c) {
    return c.value;
  });
  document.getElementById('serialized').innerText = JSON.stringify(values);
}
label {
  display: block;
}
<label>
  <input type="checkbox" name="fruits[]" value="banana">Banana
</label>
<label>
  <input type="checkbox" name="fruits[]" value="apple">Apple
</label>
<label>
  <input type="checkbox" name="fruits[]" value="peach">Peach
</label>
<label>
  <input type="checkbox" name="fruits[]" value="orange">Orange
</label>
<label>
  <input type="checkbox" name="fruits[]" value="strawberry">Strawberry
</label>
<button onclick="serialize()">Serialize
</button>
<div id="serialized">
</div>
5 голосов
/ 25 августа 2017

Версия ES6:

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

function getCheckedValues() {
  return Array.from(document.querySelectorAll('input[type="checkbox"]'))
  .filter((checkbox) => checkbox.checked)
  .map((checkbox) => checkbox.value);
}

const resultEl = document.getElementById('result');

document.getElementById('showResult').addEventListener('click', () => {
  resultEl.innerHTML = getCheckedValues();
});
<input type="checkbox" name="type" value="1" />1
<input type="checkbox" name="type" value="2" />2
<input type="checkbox" name="type" value="3" />3
<input type="checkbox" name="type" value="4" />4
<input type="checkbox" name="type" value="5" />5

<br><br>
<button id="showResult">Show checked values</button>
<br><br>
<div id="result"></div>
3 голосов
/ 09 сентября 2016
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
        return this.value;
    }).get();
...