qq_61294100 2022-12-12 17:29 采纳率: 100%
浏览 25
已结题

script中document的方法拿到标签对象

问题遇到的现象和发生背景

script中document的方法拿到标签对象

用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript ">
        //全选
        alert(document.getElementsByName("hobby"));
        // alert(document.getElementById("3"));
        function checkAll() {
            // var hobbys = document.getElementsByName("hobby");
            for (var i = 0; i < hobbys.length; i++) {
                hobbys[i].checked=true;
            }
        }
        //全不选
        function checkNo() {
            // var hobbys = document.getElementsByName("hobby");
            for (var i = 0; i < hobbys.length; i++) {
                hobbys[i].checked=false
            }
        }
        //反选
        function checkReverse() {
            // var hobbys = document.getElementsByName("hobby");

            for (var i = 0; i < hobbys.length; i++) {
                hobbys[i].checked=!hobbys[i].checked;
            }
        }
    </script>
</head>
<body>
兴趣爱好:
<input type="checkbox" name="hobby" id="3" value="cpp" checked="checked">C++
<input type="checkbox" name="hobby" value="java">Java
<input type="checkbox" name="hobby" value="js">JavaScript
<br/>
<button onclick="checkAll()">全选</button>
<button onclick="checkNo()">全不选</button>
<button onclick="checkReverse()">反选</button>
</body>
</html>
我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%

在标签中中直接使用 alert("document.getElementsByName("hobby")"),这时标签中的内容还没有加载出来,为什么就可以看到[object NodeList]这样的值,不应该显示null值吗,如果时调用alert(document.getElementById("3"));这样的方法,显示的就是null值,这是为什么呢?

  • 写回答

4条回答 默认 最新

  • 全栈小5 全栈领域优质创作者 2022-12-12 17:38
    关注

    1、因为通过name来找对象,可能是返回多个,因为没有具体指定那个,所以就返回了一个obj对象
    如果你改为具体输出NodeList的那个一个,那么就会提示没有定义了
    alert(document.getElementsByName("hobby"));

    img

    2、你那里通过id来获取对象,就是指定找一个,没找到就是返回空

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
  • dp_shiyu 2022-12-12 17:43
    关注

    img

    评论
  • 越来越好。 2022-12-12 17:45
    关注

    document.getElementsByName 获取的就是一个数组对象了,此时在alert时就是[object NodeList]。
    如果你alert第一个,例如: alert(document.getElementsByName("hobbys")[0]),那么就是undefined了。
    document.getElementById 是获取单个对象的,所以为null

    评论
  • 夜郎king 2022博客之星IT其它领域TOP 12 2022-12-12 18:03
    关注

    根据name查找确实是一个node list

    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 12月20日
  • 已采纳回答 12月12日
  • 创建了问题 12月12日

悬赏问题

  • ¥40 找同学帮敲Python代码
  • ¥15 MYSQL 订单的商品明细重复计算问题
  • ¥15 微信实时共享位置修改
  • ¥100 TG的session协议号转成直登号号后客户端登录几分钟后自动退出设备
  • ¥50 共模反馈回路的小信号增益
  • ¥15 arduino ssd1306函数与tone函数放歌代码不兼容问题
  • ¥70 0.96版本hbase的row_key里含有双引号,无法deleteall
  • ¥15 诊断性META分析合并效能的检验
  • ¥15 请问abb根据色块判断奇偶数并根据批次号放入仓储
  • ¥66 开发PC客户端一定也要开发上位机吗?