รับช่องทำเครื่องหมายที่เลือกทั้งหมดในอาร์เรย์


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 ของพวกเขาและถูกเขียนด้วยมือ (เช่นไม่ดึงจาก db) ดังนั้นพวกเขามีแนวโน้มที่จะยังคงเหมือนเดิมในขณะที่

คำถามของฉันคือฉันจะทำให้พวกมันทั้งหมดอยู่ในอาร์เรย์ (เป็นจาวาสคริปต์) ได้อย่างไรดังนั้นฉันสามารถใช้พวกมันในขณะที่ทำการ$.postร้องขอAJAX โดยใช้ Jquery

ความคิดใด ๆ

แก้ไข: ฉันต้องการให้เพิ่มกล่องกาเครื่องหมายที่เลือกไว้ในอาร์เรย์เท่านั้น



ในขณะที่คำถามอื่นนั้นใหม่กว่าและคำถามนี้ได้รับความนิยมมากกว่า แต่คำถามอื่น ๆก็มีคำตอบที่ดีกว่าและกระชับกว่าเดิม (รวมถึงกลยุทธ์ที่นี่และบางข้อ)
Jason C

คำตอบ:


332

ฟอร์แมตแล้ว:

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

หวังว่ามันจะทำงาน


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; }
M เมื่อ

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

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

6
เมื่อฉันเข้าใจรหัสข้างต้นมันซ้ำผ่านช่องทำเครื่องหมายทั้งหมดและยกเลิกการเลือก คำตอบนี้เชื่อมโยงกับคำถามอย่างไร
Terite

2
วิธีนี้จะวนซ้ำผ่านช่องทำเครื่องหมายและยกเลิกการตรวจสอบ สำหรับคำตอบที่ถูกต้องใน VanillaJS โปรดดูคำตอบของ zahid ullah ด้านล่าง
jmknoll

2
คำถามนี้จะตอบคำถามได้อย่างไร สิ่งนี้ทำสิ่งที่ไม่เกี่ยวข้องอย่างสมบูรณ์กับสิ่งที่ถาม ทำไมมี upvotes มากมาย ฉันขาดอะไรไปหรือคำถามถูกแก้ไขหลังจากมีคนโหวตขึ้น?
Shubham Chaudhary


39

ฉันไม่ได้ทดสอบ แต่ควรใช้งานได้

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

$(document).ready(function() {

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

});

</script>

กดเพื่อเพิ่มมูลค่าในอาร์เรย์ แต่จะเอาออกโดยไม่เลือก?
Jubin Patel

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

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


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


5

JavaScript ที่แท้จริงโดยไม่จำเป็นต้องมีตัวแปรชั่วคราว:

Array.from(document.querySelectorAll("input[type=checkbox][name=type]:checked")).map(e => e.value)

คำตอบที่กระชับที่สุดโดยใช้วานิลลา JS
M. Mufti


3

ในการตรวจสอบเพิ่มค่าสำหรับช่องทำเครื่องหมายและในการ dechecking ลบค่า

$('#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>


โปรดเพิ่มคำอธิบายเล็กน้อยในคำตอบของคุณ คำตอบของรหัสบริสุทธิ์มักไม่เป็นประโยชน์
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

คุณจะต้องเพิ่มคลาสให้กับทุกอินพุตฉันมีการเพิ่ม "source" คลาสคุณสามารถเปลี่ยนได้แน่นอน

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


0

ใช้ความเห็นถ้าบล็อกเพื่อป้องกันการเพิ่มค่าที่มีอยู่ในอาร์เรย์แล้วถ้าคุณใช้การคลิกปุ่มหรือสิ่งที่จะเรียกใช้การแทรก

$('#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

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


สำหรับคำตอบที่มีประโยชน์ปฏิกิริยานี้จะต้องมีการขยาย อธิบายว่าทำไมนี่คือคำตอบของคำถาม
Jeroen Heier

ยินดีต้อนรับสู่ Stack Overflow และขอบคุณสำหรับการสนับสนุนของคุณ! มันจะดีถ้าคุณอ่านคู่มือนี้วิธีการเขียนคำตอบที่ดีและปรับคำตอบของคุณ ขอบคุณ!
เดวิด

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.