西凉的悲伤 2023-08-10 17:17 采纳率: 100%
浏览 4
已结题

有没有人知道这个js代码43行为什么报错

img

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <style>
        .b2 {
            color: coral;
        }
        .info{
            color: aqua;
        }
    </style>
</head>

<body>
    <button id="b1"> 点击 </button>
    <button class="b2"> 还原 </button>
    <div class="info"> 这是一段文字</div>
</body>
<script>
    //获取所有id为“b1”的元素,并将它们存储在名为“elements”的变量中
    let btn1 = document.getElementById("b1");
    btn1.addEventListener("click", change);
    function change() {
        //遍历所有class为“info”的元素,修改其中的文本和字体颜色,并在其中加入一个a标签链接
        let elements = document.getElementsByClassName("info");
        for (let element of elements) {
            element.innerText = "这是一段新的文字";
            element.style.color = "red";

            let newA = document.createElement("a");
            newA.href = "https://www.baidu.com";
            newA.innerText = "百度";
            newA.style.marginLeft = "100px";
            newA.target = "_blank";
            element.appendChild(newA);
        }
    }

    //还原
    let btn2 = document.getElementsByClassName("b2");
    btn2.addEventListener("click",reset);
    function reset() {
        let infoDiv = document.getElementsByClassName("info");
        infoDiv.innerText = "这是一段文字";
        infoDiv.style.color = "aqua";
    }

</script>

</html>

43 行提示 btn2.addEventListener 不是个方法,这就有点离谱了。

  • 写回答

3条回答 默认 最新

  • P2441M 2023-08-10 17:20
    关注

    getElementsByClassName 返回一个元素列表啊(elements 嘛),所以要用 [0] 获取 btn2

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 8月18日
  • 已采纳回答 8月10日
  • 修改了问题 8月10日
  • 创建了问题 8月10日

悬赏问题

  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染