所以我有这些复选框:
<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中),因此我可以在使用Jquery发出AJAX $.post
请求时使用它们。
有什么想法吗?
编辑:我只希望将选中的复选框添加到数组
答案 0 :(得分:287)
格式化:
$("input:checkbox[name=type]:checked").each(function(){
yourArray.push($(this).val());
});
希望它会起作用。
答案 1 :(得分:55)
var chk_arr = document.getElementsByName("chkRights[]");
var chklength = chk_arr.length;
for(k=0;k< chklength;k++)
{
chk_arr[k].checked = false;
}
答案 2 :(得分:36)
我没有测试它,但它应该工作
<script type="text/javascript">
var selected = new Array();
$(document).ready(function() {
$("input:checkbox[name=type]:checked").each(function() {
selected.push($(this).val());
});
});
</script>
答案 3 :(得分:23)
这应该可以解决问题:
$('input:checked');
我认为你没有其他可以检查的元素,但如果你这样做,你必须让它更具体:
$('input:checkbox:checked');
$('input:checkbox').filter(':checked');
答案 4 :(得分:22)
纯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 :(得分:14)
在MooTools 1.3(撰写本文时最新):
var array = [];
$$("input[type=checkbox]:checked").each(function(i){
array.push( i.value );
});
答案 6 :(得分:12)
在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;
}
答案 7 :(得分:10)
如果你想使用一个vanilla JS,你可以像@ zahid-ullah那样做,但是避免循环:
RecipeIngredientDetails
ES6中的相同代码看起来更好:
var values = [].filter.call(document.getElementsByName('fruits[]'), function(c) {
return c.checked;
}).map(function(c) {
return c.value;
});
var values = [].filter.call(document.getElementsByName('fruits[]'), (c) => c.checked).map(c => c.value);
&#13;
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);
}
&#13;
label {
display: block;
}
&#13;
答案 8 :(得分:5)
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();
});
&#13;
<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>
&#13;
答案 9 :(得分:3)
var checkedValues = $('input:checkbox.vdrSelected:checked').map(function () {
return this.value;
}).get();
答案 10 :(得分: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>
答案 11 :(得分: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>
答案 12 :(得分:1)
按输入名称选择复选框
var category_id = [];
$.each($("input[name='yourClass[]']:checked"), function(){
category_id.push($(this).val());
});
答案 13 :(得分:1)
不需要临时变量的纯JavaScript:
Array.from(document.querySelectorAll("input[type=checkbox][name=type]:checked")).map(e => e.value)
答案 14 :(得分:1)
使用此:
var arr = $('input:checkbox:checked').map(function () {
return this.value;
}).get();
答案 15 :(得分: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,
答案 16 :(得分: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>
答案 17 :(得分: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;
}
答案 18 :(得分:0)
在现代浏览器中使用香草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
答案 19 :(得分: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>
答案 20 :(得分:0)
var array = []
$("input:checkbox[name=type]:checked").each(function(){
array.push($(this).val());
});
答案 21 :(得分:0)
可以使用我创建的这个函数
function getCheckBoxArrayValue(nameInput){
let valores = [];
let checked = document.querySelectorAll('input[name="'+nameInput+'"]:checked');
checked.forEach(input => {
let valor = input?.defaultValue || input?.value;
valores.push(valor);
});
return(valores);
}
要使用它就这样称呼它
getCheckBoxArrayValue("type");