<!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,编程新手求大神指导
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
如果放上去了,在dom没加载完成的时候就调用了
var x = document.getElementById("demo"),这时候是没有id为demo的元素的,所以x就被赋值成了null,当你点击的时候x为null,所以没反应。如果需要实现效果,可以将赋值操作放到window.onload事件完成时,
window.onload = function(){x = document.getElementById("demo");},或者放到insert方法里每次调用的时候赋值,不过那样对性能有影响。如果你想放在head里,你可以将你的代码放在
就可以了,原因楼上已经给你解释清楚了。
这行代码的意思是等到文档全部加载完后在执行代码~
因为执行js代码的时候,html还没执行到,所以获取不到html的内容,更谈不上改变html的内容