我有一个脚本可以检查并检查表单中的所有框,我的问题是我只希望它只影响我的复选框,但它也会影响我的单选按钮。
这是我的javascript
<script>
checked=false;
function checkedAll (frm1) {
var aa= document.getElementById('frm1');
if (checked == false)
{
checked = true
}
else
{
checked = false
}
for (var i =0; i < aa.elements.length; i++)
{
aa.elements[i].checked = checked;
}
}
</script>
这是我的HTML
<form id ="frm1">
<input type="checkbox" name="chk1">
<input type="radio" name="chk1">
<input type="checkbox" name="chk2">
<input type='checkbox' name='checkall' onclick='checkedAll(frm1);'>
</form>
我想知道是否有办法只检查复选框而不是单选按钮。
答案 0 :(得分:3)
for (var i =0; i < aa.elements.length; i++)
{
if (aa.elements[i].type == "checkbox") {
aa.elements[i].checked = checked;
}
}
答案 1 :(得分:0)
您可以遍历表单元素并检查“type”属性。或者,你可以使用像jQuery这样的javascript库,这样可以更容易地选择某种类型的元素。
var elLength = document.MyForm.elements.length;
for (i=0; i<elLength; i++)
{
var type = MyForm.elements[i].type;
if (type=="checkbox" && MyForm.elements[i].checked){
alert("Form element in position " + i + " is of type checkbox and is checked.");
}
else if (type=="checkbox") {
alert("Form element in position " + i + " is of type checkbox and is not checked.");
}
else {
}
}
在jQuery中它将是:
$("input[type='checkbox']).each(function(chk) {
chk.checked = !chk.checked;
});
答案 2 :(得分:0)
您可以使用jquery。在编辑器中使用下面的html代码。它工作正常!
<html>
<head>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.0.js"> </script>
</head>
<form id="myform">
<input type="checkbox" />chk1
<input type="checkbox" />chk2<br/>
<input type="radio" />radio1<br/>
<a style="cursor:pointer" onclick="ch()">check/uncheck</a>
</form>
</body></html>
和这个脚本:
<script>
function ch(){
$("form#myform input[type='checkbox']").each(function(chk) {
this.checked = !this.checked;
});
}
</script>