ss003620
2012-08-23 16:48
浏览 229

关于js全选反选的问题

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
function showHobby(){
var hobbyObj=document.hobby.userHobby;
for(var i=0;i<hobbyObj.length;i++){
hobbyObj[i].checked=true;
}
}
function showHobby2(){
var hobbyObj=document.hobby.userHobby;
for(var i=0;i<hobbyObj.length;i++){
hobbyObj[i].checked=false;
}
}
function showHobby3(){
var hobbyObj=document.hobby.userHobby;
for(var i=0;i<hobbyObj.length;i++){
hobbyObj[i].checked=!hobbyObj[i].checked;
}
}
</script>
</head>

<body>
<form action="" name="hobby" method="get">
足球<input type="checkbox" name="userHobby" value="zu" />
<input type="button" value="全选" onclick="showHobby()"/>
<input type="button" value="不全选" onclick="showHobby2()">
<input type="button" value="反选" onclick="showHobby3()">
</form>
</body>
</html>

 如上代码,为复选的全选全不选反选功能,当只有一个复选时三个功能都失效了
但将获取对象的代码var hobbyObj=document.hobby.userHobby;更换为
var hobbyObj=document.getElementsByName("userHobby");时,单个复选还可以用着三个功能,为什么呢?

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • iteye_7115 2012-08-23 17:15
    已采纳

    当checkbox多个时document.hobby.userHobby和document.getElementsByName("userHobby") 返回的都是一个包含checkbox控件的数组,所以都存在length属性
    但当checkbox只有一个的时候,document.hobby.userHobby返回的是不是数组,而是直接对应的那个控件,所以不存在length属性

    打赏 评论
  • Dead_Knight 2012-08-23 19:05

    [code="java"]
    function selectAll()
    {
    var check_item = document.hobby.userHobby;
    if(check_item)
    {
    if(typeof(check_item.length) == "undefined")
    {
    check_item.checked = "true";

    }
    else
    {
    for(i=0;i<check_item.length;i++)
    {
    check_item[i].checked = "true";
    }
    }
    }
    }
    [/code]

    打赏 评论

相关推荐 更多相似问题