前端入门,js操作html元素,

<!DOCTYPE html>
<html>
<!--遇到问题了,为什么把script放在body外边不能执行呢-->
<head>
    <meta charset="utf-8">
    <title>如需从 JavaScript 访问某个 HTML 元素,</title>
</head>
<body>
    <h1>访问html元素,并插入元素内容</h1>
    <p id="demo">段落用来插入元素</p>
    <button type="button" onclick="insert()">点我改变p元素内容</button>
    <script>
        var x = document.getElementById("demo");

        function insert() {
            x.innerHTML = "插入内容";
        }
    </script>
</body>

</html>

代码如上,如果把script提到head中,就无法执行js,编程新手求大神指导

阅读 2.9k
3 个回答

如果放上去了,在dom没加载完成的时候就调用了var x = document.getElementById("demo"),这时候是没有id为demo的元素的,所以x就被赋值成了null,当你点击的时候x为null,所以没反应。
如果需要实现效果,可以将赋值操作放到window.onload事件完成时,window.onload = function(){x = document.getElementById("demo");},或者放到insert方法里每次调用的时候赋值,不过那样对性能有影响。

新手上路,请多包涵

如果你想放在head里,你可以将你的代码放在

window.onload=function(){
//代码放在这里
}

就可以了,原因楼上已经给你解释清楚了。
这行代码的意思是等到文档全部加载完后在执行代码~

因为执行js代码的时候,html还没执行到,所以获取不到html的内容,更谈不上改变html的内容

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题