Javascript中基础-词法作用域

词法作用域:变量的作用域是在定义时决定而不是执行时决定,也就是说词法作用域取决于源码,通过静态分析就能确定,因此词法作用域也叫做静态作用域。 with和eval除外,所以只能说JS的作用域机制非常接近词法作用域(Lexical scope)。

作用域链:词法作用域的实现机制就是作用域链(scopeChain)。作用域链是一套按名称查找(Name Lookup)的机制,首先在当前执行环境的 ActiveObject 中寻找,没找到,则顺着作用域链到父 ActiveObject 中寻找,一直找到全局调用对象(Global Object)

  • 变量查找规则是首先在当前执行环境的 ActiveObject 中寻找,没找到,则顺着执行环境中属性 ScopeChain 指向的 ActiveObject 中寻找,一直到 Global Object(window)方法执行完成后,内部变量值不会被重置,至于变量什么时候被销毁,请参考下面一条方法内变量的生存周期取决于方法实例是否存在活动引用,如没有就销毁活动对象 
在一个方法中,同名的实参,形参和变量之间是引用关系,也就是JS引擎的处理是同名变量和形参都引用同一个内存地址】,

经典案例
  1. /*全局(window)域下的一段代码*/
  2. var i=10;
  3. function a(){
  4. alert(i);
  5. vari = 2;
  6. alert(i);
  7. };
  8. a();

疑问:上面的代码又会输出什么呢?(小子,看这回整不死你!哇哈哈,就不给你选项)
答案:在FireBug中的运行结果是 undefined, 2,下面简单说一下具体执行过程

  1. 第一个alert输出undefined
  2. 第二个alert输出 2
  3. 思考:到底怎么回事儿? 

根据【JS引擎变量查找规则,首先在当前执行环境的 ActiveObject 中寻找,没找到,则顺着执行环境中属性 ScopeChain 指向的 ActiveObject 中寻找,一直到 Global Object(window)】,所以在案例中,因为在当前的ActiveObject中找到了有变量 i 的定义,只是值为 “undefined”,所以直接输出 “undefined” 了

<pre name="code" class="javascript">                   <pre name="code" class="javascript" style="font-weight: bold;">                     var name = "Andyfu";<span style="font-family: Arial, Helvetica, sans-serif;">         </span>

 
                 function init() {
				

				function displayName() {
					alert(name);
				};
				var name = "Mozila";
                               displayName();
			}
			init();//Mosila


 
                      var name = "Andyfu";

			function init() {
				function displayName() {
					alert(name);
				};
				displayName();
				var name = "Mozila";
			}
			init(); //undefined
	                var name = "Andyfu";
			function init() {
				function displayName() {
					alert(name);
				};
				displayName();
				name = "Mozila";
			}
			init(); //Andyfu
                     var name = "Andyfu";

			function init() {
				function displayName() {
					alert(name);
				};
				
				name = "Mozila";
				displayName();
			}
			init(); //Mozila
                          var name = "Andyfu";
			function init() 
                       {
				(function() {
					alert(name);
				})();<span style="font-family: Arial, Helvetica, sans-serif;">//自执行函数</span>
				var name = "Mozila";
			
			}
			init(); //undefined

	            var name = "Andyfu";

			function init() {
				(function() {
					alert(name);
				})();//自执行函数
				
			name = "Mozila";
			
			}
			init(); //Andyfu
                      var a = 10;

			function test() {
				a = 100;
				alert(a);
				alert(this.a);
				var a;
				alert(a);
			}
			test();//100 10 100
	                var a = 10;

			function test() {
				a = 100;
				alert(a);
				alert(this.a);
				//var a;
				alert(a);
			}
			test();//100 100 100

                          var a = 10;
                           alert(this.a);
                           a=50;
			function test() {
				a = 100;
				alert(a);
				alert(this.a);
				var a;
				alert(a);
			}
			test();//10 100 50 100









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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值