208

だから私はこれらのチェックボックスを持っています:

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

$.post私の質問は、 Jquery を使用して AJAX リクエストを作成するときにそれらを使用できるように、それらをすべて配列 (javascript) で取得する方法です。

何かご意見は?

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

4

23 に答える 23

394

フォーマット済み:

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

うまくいけば、うまくいくでしょう。

于 2009-02-26T10:52:41.420 に答える
56
var chk_arr =  document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;             

for(k=0;k< chklength;k++)
{
    chk_arr[k].checked = false;
} 
于 2012-03-02T07:45:24.710 に答える
24

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

$('input:checked');

チェックできる他の要素があるとは思いませんが、もしそうなら、より具体的にする必要があります:

$('input:checkbox:checked');

$('input:checkbox').filter(':checked');
于 2009-02-26T10:53:57.050 に答える
14

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

var array = [];
$$("input[type=checkbox]:checked").each(function(i){
    array.push( i.value );
});
于 2011-06-26T12:45:24.933 に答える
14

バニラ 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>

于 2016-08-18T11:53:00.530 に答える
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;
}   
于 2015-05-10T06:01:31.333 に答える
5
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
        return this.value;
    }).get();
于 2016-09-09T16:57:13.870 に答える
3

最新のブラウザー (IE サポートなし、悲しいことに、執筆時点では iOS Safari サポートなし) のバニラ JS でこれを行う別の方法は、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
于 2019-07-02T10:16:13.977 に答える
2

入力名でチェックボックスを選択

var category_id = [];

$.each($("input[name='yourClass[]']:checked"), function(){                    
    category_id.push($(this).val());
});
于 2021-03-04T09:05:33.823 に答える
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>
于 2016-03-16T10:09:01.830 に答える
1
var array = []
    $("input:checkbox[name=type]:checked").each(function(){
        array.push($(this).val());
    });
于 2020-05-04T20:16:46.597 に答える
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;
}

于 2019-04-07T06:49:59.093 に答える