Получение всех выбранных флажков в массиве

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запроса AJAX с использованием Jquery.

Есть предположения?

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

Нажмите Upvote
источник
Возможный дубликат массива множественных
Jason C
В то время как другой вопрос более новый, и этот более популярен, у другого есть лучший, более краткий набор ответов (включая стратегии здесь, плюс некоторые).
Джейсон С

Ответы:

333

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

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

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

YBO
источник
1
и что делать, если снять флажок, чтобы удалить значение из массива
Jubin Patel
@JubinPatel вам просто нужно сбросить массив перед этим кодом. yourArray = []
RRK
11
Вы также можете сразу определить свой массив, используя mapвместо 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; }
М в
50
var chk_arr =  document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;             

for(k=0;k< chklength;k++)
{
    chk_arr[k].checked = false;
} 
Milind
источник
6
Как я понимаю код выше, он проходит через все флажки и снимите их. Как этот ответ связан с вопросом?
Terite
2
Это просто перебирает флажки и снимает их. Для правильного ответа, в VanillaJS, пожалуйста, смотрите ответ Захида Уллы ниже.
jmknoll
2
Как это отвечает на вопрос? Это делает что-то совершенно не связанное с тем, что просят. Почему так много голосов? Я что-то упустил, или вопрос был отредактирован после того, как люди проголосовали за него?
Шубхам Чаудхари
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>
Барбарос Алп
источник
нажмите, чтобы добавить значение в массиве, но что убрать при снятии флажка?
Джубин Патель
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 );
});
LeeGee
источник
7
Не понял, возраст вопроса или характер решения был актуален.
LeeGee
4
Потому что я нашел этот вопрос, когда искал ответ на ту же проблему, используя MooTools.
LeeGee
Обратите внимание, что этот ответ относится к 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);

Terite
источник
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);

quotesBro
источник
5

Чистый JavaScript без временных переменных:

Array.from(document.querySelectorAll("input[type=checkbox][name=type]:checked")).map(e => e.value)
Уилберт
источник
Самое краткое решение с использованием ванили JS
М. Муфти
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>

Joepraveen
источник
Пожалуйста, добавьте немного объяснения к вашему ответу. Чистый код ответов обычно не полезен.
sjaustirni
3

Другой способ сделать это с помощью vanilla 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();
МХК
источник
1

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

Капил
источник
Для полезного ответа эта реакция должна быть расширена. Объясните, почему это ответ на вопрос.
Йерун Хейер
Добро пожаловать в Stack Overflow и спасибо за ваш вклад! Было бы неплохо, если бы вы прочитали это руководство. Как написать хороший ответ и соответствующим образом скорректировать свой ответ. Спасибо!
Дэвид
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
var array = []
    $("input:checkbox[name=type]:checked").each(function(){
        array.push($(this).val());
    });
Salione
источник