javaScript变量的作用范围

本文详细解释了JavaScript中变量的全局作用域与局部作用域的区别,包括如何定义全局变量与局部变量,以及局部变量如何覆盖全局变量的情况。同时,还探讨了JavaScript中不存在块级作用域的特点,并通过实例演示了变量作用域在HTML事件处理中的应用。

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

 根据作用范围不同,变量有全局变量和局部变量两种
Java代码 复制代码
  1. <script>   
  2.     //定义全局变量test   
  3.     var test = "全局变量";    
  4.     function checkscope(  )   
  5.     {   
  6.         var test = "局部变量";   
  7.         alert(test);   
  8.     }   
  9.     checkscope(  );    
  10. //在函数里定义的变量为局部变量,局部变量只在函数内有效。   
  11. //如果局部变量和全局变量用相同的变量名,则局部变量将覆盖全局变量   
  12. </script>  
<script>
	//定义全局变量test
	var test = "全局变量"; 
	function checkscope(  )
	{
		var test = "局部变量";
		alert(test);
	}
	checkscope(  ); 
//在函数里定义的变量为局部变量,局部变量只在函数内有效。
//如果局部变量和全局变量用相同的变量名,则局部变量将覆盖全局变量
</script>


        JavaScript语言没有块范围:

Java代码 复制代码
  1. <script>   
  2.     function test(o)       
  3.     {   
  4.         //定义变量i,变量i的作用范围是整个函数   
  5.             var i = 0;   
  6.         if (typeof o == "object")    
  7.         {   
  8.             //定义变量j,变量j的作用范围是整个函数内,而不是if块内。   
  9.                 var j = 5;   
  10.                 for(var k = 0; k < 10; k++)   
  11.                 {   
  12.                 //k的作用范围是整个函数内,而不是循环体内   
  13.                     document.write(k);   
  14.                 }   
  15.         }      
  16.         //即使出了循环体,k的值依然存在   
  17.         alert(k + "/n" + j);    
  18.     }   
  19.     test(document);   
  20. </script>  
<script>
	function test(o)	
	{
		//定义变量i,变量i的作用范围是整个函数
			var i = 0;
		if (typeof o == "object") 
		{
			//定义变量j,变量j的作用范围是整个函数内,而不是if块内。
				var j = 5;
				for(var k = 0; k < 10; k++)
				{
				//k的作用范围是整个函数内,而不是循环体内
					document.write(k);
				}
		}	
		//即使出了循环体,k的值依然存在
		alert(k + "/n" + j); 
	}
	test(document);
</script>


        因为JavaScript语言没有块范围,有时会出现一些非常奇怪的结果:

Java代码 复制代码
  1. <script>   
  2.   
  3.     var scope = "全局变量";   
  4.     function test()   
  5.     {   
  6.         alert(scope);    
  7.         var scope = "局部变量";   
  8.         alert(scope);    
  9.     }   
  10.     test();   
  11. //代码第一次输出的scope值并不是"全局变量",而是undefined。知识这是因为scope在test函数中已经被重新定义了,局部变量在test函数中将全局有效,即在scope还没定义之前全局变量scope依然被覆盖。   
  12. </script>  
<script>

	var scope = "全局变量";
	function test()
	{
		alert(scope); 
		var scope = "局部变量";
		alert(scope); 
	}
	test();
//代码第一次输出的scope值并不是"全局变量",而是undefined。知识这是因为scope在test函数中已经被重新定义了,局部变量在test函数中将全局有效,即在scope还没定义之前全局变量scope依然被覆盖。
</script>


变量作用范围在进行HTML事件处理时一样有效:
Java代码 复制代码
  1. <script type="text/javascript">   
  2.   var x = "全局变量";   
  3. </script>   
  4.   
  5. <form action="#" method="get">   
  6. <input type="button" value="局部变量"    
  7.   onclick="var x = '局部变量'; alert('输出x局部变量的值:' + x);" />   
  8. <input type="button" value="全局变量 "    
  9.   onclick="alert('输出x全局变量的值: ' + x);" />   
  10. </form>  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值