你必须知道的Javascript知识点之"深入理解作用域链"的介绍

 更新时间:2013年04月23日 10:23:53   作者:  
本篇文章小编为大家介绍,你必须知道的Javascript知识点之"深入理解作用域链"的介绍。需要的朋友参考下
示例代码:
复制代码 代码如下:

var xxxVar1 = 1;
 var outer = function(){
    var xxxVar2 = 2;

    var results = [];

    for(var i = 0; i< 3; i++)
    {
       var inner = function(){
          var xxxVar3 = 3;
          return xxxVar3 + xxxVar2 +xxxVar1 + i;
       }
       results .push(inner);
    }

    return results;
 }

 var xxxVar1 = 100;
 var xxxVar2 = 200;
 var xxxVar3 = 300;
 var results = outer();
 results[0]();
 results[1]();
 results[2]();

执行结果

发生了什么事情很多人都可能知道上例的执行结果,但是不是所有人都明白为什么会是这样的结果,包括我自己。名词解释活动对象:一次函数调用开始的时候,javascript解释器会收集函数体中的所有局部变量(以var形式声明的变量),将这些局部变量存储到一个称为“活动对象”的对象里,所有变量都初始为undefined。
代码示例
复制代码 代码如下:

var fun = function(){
    alert(name);
    var name = '段光伟';
 }

当执行这个函数时候时(fun()),函数体还没执行到,当前的活动对象为[{ name: undefined }],因此fun()执行的结果为:

  • 函数的[scope]属性:每个函数在定义的时候(生成函数实例的时候)都会分配一个[scope]属性,这个属性指向的当前的“作用域链”。这个属性开发人员是访问不到的,只有javascript能访问。
  • 作用域链:当函数调用时,javascript引擎会维护一个这次调用的作用域链,这个作用域链条是函数的[scope]指向的作用域链加上函数调用时的活动对象,形式如[ 活动对象, 函数定义时的作用域链条]。
    代码示例
    复制代码 代码如下:

    var a = 1;
     //步骤1:[ { a: 1, outer: undefined } ]

     var outer = function(){
        //步骤3:[ { b: undefined, inner: undefined } ,{ a: 1, outer: function } ]
        var b = 2;
        var inner = function(){
           //步骤5:[ {}, { b: 2, inner: function } ,{ a: 1, outer: function } ]
           return a + b;
        }

        //步骤4:[ { b: 2, inner: function } ,{ a: 1, outer: function } ]
        return inner();
     }

     //步骤2:[ { a: 1, outer: function } ]
     outer();

    作用域链规则规则1

    javascript一般运行在一定的宿主中,每个宿主都会提供一个“全局对象”,或者叫“全局活动对象”,这个全局对象是所有作用域链的根节点。

    规则2

     “取值操作”(如:alert(xxxVar))的规则是,沿着作用域链依次查找名称为“xxxVar”的变量,返回第一个找到的值,如果找不到就抛出异常(ReferenceError: xxxVar is not defined)。

    规则3

     “赋值操作”(如:xxxVar = '段光伟')的规则是,沿着作用域链依次查找名称为“xxxVar”的变量,覆盖第一个找到的值,如果找不到就将“xxxVar”添加到全局对象中。

    备注“闭包”这个概念就是通过“作用域链”实现的,而C#是通过编译器实现的,.NET并不支持。
  • 相关文章

    • JS实现横向轮播图(中级版)

      JS实现横向轮播图(中级版)

      这篇文章主要为大家详细介绍了JS实现横向轮播图的中级版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2020-01-01
    • KnockoutJS 3.X API 第四章之数据控制流with绑定

      KnockoutJS 3.X API 第四章之数据控制流with绑定

      这篇文章主要介绍了KnockoutJS 3.X API 第四章之数据控制流with绑定的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
      2016-10-10
    • javascript中clipboardData对象用法详解

      javascript中clipboardData对象用法详解

      这篇文章主要介绍了javascript中clipboardData对象用法,详细分析了clipboardData对象的功能及相关使用技巧,需要的朋友可以参考下
      2015-05-05
    • 详解JS面向对象编程

      详解JS面向对象编程

      这篇文章主要为大家介绍了js面向对象编程,感兴趣的小伙伴们可以参考一下
      2016-01-01
    • 解决layui的使用以及针对select、radio等表单组件不显示的问题

      解决layui的使用以及针对select、radio等表单组件不显示的问题

      今天小编就为大家分享一篇解决layui的使用以及针对select、radio等表单组件不显示的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
      2019-09-09
    • JavaScript实现滑块补图验证码效果

      JavaScript实现滑块补图验证码效果

      这篇文章主要给大家介绍了JavaScript如何实现滑块补图验证码效果,文章通过代码示例介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴可以参考阅读下
      2023-07-07
    • 深入浅析var,let,const的异同点

      深入浅析var,let,const的异同点

      这篇文章主要介绍了var,let,const异同点,文中较详细的给大家介绍了let和const的相同点和不同点,需要的朋友可以参考下
      2018-08-08
    • js获取浏览器和屏幕的各种宽度高度

      js获取浏览器和屏幕的各种宽度高度

      本文主要介绍了js获取浏览器和屏幕的各种宽度高度的方法,具有很好的参考价值,下面跟着小编一起来看下吧
      2017-02-02
    • 详解weex默认webpack.config.js改造

      详解weex默认webpack.config.js改造

      本篇文章主要介绍了详解weex默认webpack.config.js改造,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
      2018-01-01
    • JS异步处理的进化史深入讲解

      JS异步处理的进化史深入讲解

      这篇文章主要给大家介绍了关于JS异步处理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用JS具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
      2019-08-08

    最新评论