为什么要等页面加载完毕才加载JavaScript代码?

  首先,我需要通过JavaScript代码将h2标签里的文字变成红色。话不多说,直接甩代码。跟我来一起比较代码一和代码二。

代码一:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>小飞自学编程</title>
</head>
<body>
<script>
	var get = document.getElementById("h1");
	get.style.color = "red";
</script>

	<h2 id="h1">我是小飞</h2>

</body>
</html>

  结果:浏览器只是显示了加粗的文字,并没有按原先的想法变成红色。同时报了一个错误(未捕获的类型错误:不能读取无效的style属性。)
在这里插入图片描述

在这里插入图片描述

代码二:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>小飞自学编程</title>
</head>
<body>

<h2 id="h1">我是小飞</h2>

<script>
	var get = document.getElementById("h1");
	get.style.color = "red";
</script>

</body>
</html>

  结果:浏览器正常显示,未报错,得到了我想要的结果。在这里插入图片描述
分析:
  当h2标签放到了script标签前面后,js代码能够正常运行了。
  这意味着浏览器需要等到页面加载完毕之后才能执行js代码,因为如果先加载了js代码的话,此时 DOM 未加载,如果在 js 中获取 dom 节点是获取不到的。

总结:
  为了避免js出现以上的错误,我们应该将js代码放到</body>(结束标签)之前。同时,你应该注意到一个细节,</body>结束标签与</script>结束标签是紧挨着的,它们之间没有html代码。

<body>
<script>
	//这里放js代码
</script>
</body>


//或者写成
<body>
<script>
	window.onload =function(){
  //js代码
}
</script>
</body>

  或者在进行外部js代码引入的时候,应该将js代码进行如下书写,这样做的目的是保证在页面加载完后再运行js代码。

window.onload =function(){
  //js代码
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值