‘ Uncaught TypeError: Cannot set properties of null ‘ 错误解决【Javascript】

本文详细解释了在JavaScript中遇到的‘UncaughtTypeError: Cannot set properties of null’错误,重点在于代码位置不当导致的变量作用域问题,以及如何通过调整脚本位置来避免此类错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

’ Uncaught TypeError: Cannot set properties of null ’ 错误解决【Javascript】



错误代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<script type="text/javascript">
		const cars = ["Tesls", "Volvo", "BMW"];
		document.getElementById("demo").innerHTML = cars;
	</script>
	<body>
		<h1>JavaScript 数组</h1>
		<p>Array 对象用于单个变量中存储多个值:</p>
		<p id="demo"></p>
	</body>
</html>

在这里插入图片描述

在这里插入图片描述
根据如图可知:

不能捕捉到类型数据错误。

错误原因
因为 js脚本写在了body前面
网页编译脚本的时候,是从上往下编译,
由于编译脚本的时候body还没编译到,所以读取不到这个变量范围,这时候只要把我们写的js脚本的代码写在body下面就可以了。

正确代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<h1>JavaScript 数组</h1>
		<p>Array 对象用于单个变量中存储多个值:</p>
		<p id="demo"></p>
	</body>
	<script type="text/javascript">
		const cars = ["Tesls", "Volvo", "BMW"];
		document.getElementById("demo").innerHTML = cars;
	</script>
</html>

总结
其实一般会出现这种错误,其实就是我们定义的变量范围作用域查找不到,这时候就需要仔细研究出错的变量在运行的时候是否作用域范围对或者变量的值是否存在。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值