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