第九天,js之变量作用域


全局变量:在全局范围内(不在函数内)定义的变量(不管是否使用var)、不适用var定义的变量都是全局变量,全局变量可以被所有的脚本访问。

局部变量:在函数里定义的变量称为局部变量,局部变量只在函数内生效。


案例一:

	<script>
		var a = "全局变量a";
		function myfun(){
			var istrue = true;
			b = "全局变量b";
		}
	</script>
	<div>
	</div>
	<script>
		alert(a);
	</script>



因为a的定义不在函数内,所以可以显示。


案例二:

	<script>
		var a = "全局变量a";
		function myfun(){
			var istrue = true;
			b = "全局变量b";
		}
	</script>
	<div>
	</div>
	<script>
		alert(b);
	</script>



b虽然定义在函数内,但是没有用var定义,按理说因该是全局啊,怎么提示没有定义呢?原因在案例三。


案例三:

	<script>
		var a = "全局变量a";
		function myfun(){
			var istrue = true;
			b = "全局变量b";
		}
	</script>
	<div>
	</div>
	<script>
		myfun();
		alert(b);
	</script>



因为虽然b在函数内,且没有用var定义,但是必须在执行过myfun()函数之后,它才会成为真正的全局变量。


案例四:

	<script>
		var a = "全局变量a";
		function myfun(){
			var istrue = true;
			b = "全局变量b";
		}
	</script>
	<div>
	</div>
	<script>
		alert(istrue);
	</script>


因为istrue定义在函数内,且用var定义,所以为局部变量。

猜你喜欢

转载自blog.csdn.net/qq_38006520/article/details/81056823
今日推荐