web-dev-qa-db-ja.com

配列内の選択されたすべてのチェックボックスを取得する

だから私はこれらのチェックボックスがあります:

<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つがあり、手動でコーディングされている(すなわち、dbからフェッチされていない)ので、しばらくの間同じままである可​​能性があります。

私の質問は、それらをすべて(JavaScriptで)配列で取得する方法です。そのため、Jqueryを使用してAJAX $.postリクエストを作成しながらそれらを使用できます。

何かご意見は?

編集:選択したチェックボックスだけを配列に追加したい

144
Click Upvote

フォーマット済み:

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

うまくいけば、それはうまくいくでしょう。

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

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

私はそれをテストしませんでしたが、うまくいくはずです

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

$(document).ready(function() {

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

});

</script>
37
Barbaros Alp

これでうまくいくはずです。

$('input:checked');

他にチェックできる要素があるとは思いませんが、そうであれば、より具体的にする必要があります。

$('input:checkbox:checked');

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

純粋な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)
}
22
Chris Underdown

MooTools 1.3(執筆時点で最新):

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

Javascriptでは、このようになります (Demo Link)

// 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
zahid ullah

Vanilla 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>
10
Terite

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

チェックするとチェックボックスの値を加算し、チェックを外すと値を減算する

$('#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>
3
Joepraveen
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
        return this.value;
    }).get();
3
Jean-Marc Amon

最近のブラウザで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
foz

これを使って:

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

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

ボタンクリックまたは挿入を実行するために何かを使用した場合にすでに配列内にある値を追加しないようにするには、コメント付きの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
Nisal Edu

ここに誰かがこれを試すことができる同じ問題のための私のコードがあります。 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
Rahul Gupta

あなたはこのようなことを試すことができます:

$('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
pappu kr Sharma