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


Posted in Javascript onApril 23, 2013

示例代码:

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知识点之&quot;深入理解作用域链&quot;的介绍

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

当执行这个函数时候时(fun()),函数体还没执行到,当前的活动对象为[{ name: undefined }],因此fun()执行的结果为:
你必须知道的Javascript知识点之&quot;深入理解作用域链&quot;的介绍
  • 函数的[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并不支持。
  • Javascript 相关文章推荐
    SWFObject Flash js调用类
    Jul 08 Javascript
    各浏览器对document.getElementById等方法的实现差异解析
    Dec 05 Javascript
    AngularJS + Node.js + MongoDB开发的基于高德地图位置的通讯录
    Jan 02 Javascript
    jQuery动态修改超链接地址的方法
    Feb 13 Javascript
    JS获取IE版本号与HTML设置IE文档模式的方法
    Oct 09 Javascript
    js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
    Dec 06 Javascript
    BootStrap栅格系统、表单样式与按钮样式源码解析
    Jan 20 Javascript
    自带气泡提示的vue校验插件(vue-verify-pop)
    Apr 07 Javascript
    vue-cli + sass 的正确打开方式图文详解
    Oct 27 Javascript
    Angular2进阶之如何避免Dom误区
    Apr 02 Javascript
    AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
    May 17 Javascript
    angular异步验证器防抖实例详解
    Mar 31 Javascript
    你必须知道的Javascript知识点之&quot;字面量和对应类型&quot;说明介绍
    Apr 23 #Javascript
    你必须知道的Javascript知识点之&quot;单线程事件驱动&quot;的使用
    Apr 23 #Javascript
    你必须知道的Javascript知识点之&quot;this指针&quot;的应用
    Apr 23 #Javascript
    jquery清空textarea等输入框实现代码
    Apr 22 #Javascript
    js计算精度问题小结
    Apr 22 #Javascript
    基于javascipt-dom编程 table对象的使用
    Apr 22 #Javascript
    用js实现小球的自由移动代码
    Apr 22 #Javascript
    You might like
    解析php中获取url与物理路径的总结
    2013/06/21 PHP
    ThinkPHP的截取字符串函数无法显示省略号的解决方法
    2014/06/25 PHP
    jQuery获取json后使用zy_tmpl生成下拉菜单
    2015/03/27 PHP
    php使用array_chunk函数将一个数组分割成多个数组
    2018/12/05 PHP
    TP5框架model常见操作示例小结【增删改查、聚合、时间戳、软删除等】
    2020/04/05 PHP
    关于B/S判断浏览器断开的问题讨论
    2008/10/29 Javascript
    Extjs实现进度条的两种便捷方式
    2013/09/26 Javascript
    innerHTML中标签可以换行的方法汇总
    2015/08/14 Javascript
    JavaScript使用DeviceOne开发实战(四)仿优酷视频应用
    2015/12/02 Javascript
    jquery 属性选择器(匹配具有指定属性的元素)
    2016/09/06 Javascript
    利用JQuery实现datatables插件的增加和删除行功能
    2017/01/06 Javascript
    javascript实现秒表计时器的制作方法
    2017/02/16 Javascript
    jquery实现自定义图片裁剪功能【推荐】
    2017/03/08 Javascript
    微信小程序 生命周期函数详解
    2017/05/24 Javascript
    jQuery选择器特殊字符与属性空格问题
    2017/08/14 jQuery
    JavaScript全屏和退出全屏事件总结(附代码)
    2017/08/17 Javascript
    webstorm中vue语法的支持详解
    2018/05/09 Javascript
    vue中引用swiper轮播插件的教程详解
    2018/08/16 Javascript
    微信小程序实现树莓派(raspberry pi)小车控制
    2020/02/12 Javascript
    微信小程序实现加入购物车滑动轨迹
    2020/11/18 Javascript
    jQuery实现鼠标拖动图片功能
    2021/03/04 jQuery
    理解python多线程(python多线程简明教程)
    2014/06/09 Python
    python根据出生日期返回年龄的方法
    2015/03/26 Python
    Tornado高并发处理方法实例代码
    2018/01/15 Python
    浅谈numpy中np.array()与np.asarray的区别以及.tolist
    2020/06/03 Python
    Python collections.defaultdict模块用法详解
    2020/06/18 Python
    python实现按日期归档文件
    2021/01/30 Python
    年度献血先进个人事迹材料
    2014/02/14 职场文书
    经典促销广告词大全
    2014/03/19 职场文书
    小学生寒假家长评语
    2014/04/16 职场文书
    电工技术比武方案
    2014/05/11 职场文书
    缓刑期间思想汇报范文
    2014/10/10 职场文书
    政风行风整改报告
    2014/11/06 职场文书
    2015年项目工作总结
    2015/04/29 职场文书
    交通事故被告代理词
    2015/05/23 职场文书
    Python的这些库,你知道多少?
    2021/06/09 Python