沉淀sync 2022-12-11 14:10 采纳率: 40%
浏览 14

js获取到dom对象打印长度为0

var box = document.getElementsByName("id");
            console.log(box);
            var modify = document.getElementsByClassName("modify");
            console.log(modify);
            console.log(modify.length);
            for (var i = 0; i < modify.length; i++) {
                modify[i].onclick = function (e) {
                    console.log(e.target.parentElement.parentElement);
                    if (box[e.target.parentElement.parentElement.rowIndex].checked) {
                        alert("点击了第" + e.target.parentElement.parentElement.rowIndex + "行");
                    }
                    else {
                        alert("未选中");
                    }
                }
            }

运行后在控制台打印modify是一个集合,但是打印modify.length却为0。

img


这里的dom对象是从php打印出来的

while($stmt->fetch())
        {
            echo "<tr><td><input type=\"checkbox\" value=\"{$n}\" name=\"id\"></td><td>{$pro_name}</td><td>{$pro_count}</td>";
            echo "<td><button class=\"modify\">修改</button></td><td><button class=\"delete\">删除</button></td></tr>";
            $n++;
        }

  • 写回答

1条回答 默认 最新

  • 谷雨睡不醒 2022-12-11 18:41
    关注

    一个猜想不一定对,
    就是刚进这个页面执行到for循环的时候dom元素还没有加载出来所以这时候他的length是0,
    至于为啥你看控制台展开里面有元素呢因为console输出的时候只会输出第一层然后你展开的时候才会加载里面的层。但是这个时候dom元素已经渲染出来了所以展开的时候里面是有元素的。
    所以就出现了这么一个打印长度是0但是可以展开的情况,
    你可以在输出长度的下面打一个debugger断点看一下当时的情况。

    评论

报告相同问题?

问题事件

  • 创建了问题 12月11日

悬赏问题

  • ¥15 c++2013读写oracle
  • ¥15 c++ gmssl sm2验签demo
  • ¥15 关于模的完全剩余系(关键词-数学方法)
  • ¥15 有没有人懂这个博图程序怎么写,还要跟SFB连接,真的不会,求帮助
  • ¥30 模拟电路 logisim
  • ¥15 PVE8.2.7无法成功使用a5000的vGPU,什么原因
  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音