你必须知道的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 相关文章推荐
    javascript引导程序
    Oct 26 Javascript
    jQuery live( type, fn ) 委派事件实现
    Oct 11 Javascript
    点弹代码 点击页面任何位置都可以弹出页面效果代码
    Sep 17 Javascript
    解析img图片没找到onerror事件 Stack overflow at line: 0
    Dec 23 Javascript
    Winform客户端向web地址传参接收参数的方法
    May 17 Javascript
    浅谈js内置对象Math的属性和方法(推荐)
    Sep 19 Javascript
    Three.js利用Detector.js插件如何实现兼容性检测详解
    Sep 26 Javascript
    一步步教你利用Docker设置Node.js
    Nov 20 Javascript
    vant(ZanUi)结合async-validator实现表单验证的方法
    Dec 06 Javascript
    ES6 class的应用实例分析
    Jun 27 Javascript
    Vue 实现前端权限控制的示例代码
    Jul 09 Javascript
    layui table设置某一行的字体颜色方法
    Sep 05 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 4.2书写安全的脚本
    2006/10/09 PHP
    PHP写的求多项式导数的函数代码
    2012/07/04 PHP
    用Php编写注册后Email激活验证的实例代码
    2013/03/11 PHP
    中高级PHP程序员应该掌握哪些技术?
    2016/09/23 PHP
    thinkphp5框架实现数据库读取的数据转换成json格式示例
    2019/10/10 PHP
    PHP多进程简单实例小结
    2019/11/09 PHP
    php设计模式之状态模式实例分析【星际争霸游戏案例】
    2020/03/26 PHP
    jquery中获得元素尺寸和坐标的方法整理
    2014/05/18 Javascript
    jQuery实现提交按钮点击后变成正在处理字样并禁止点击的方法
    2015/03/24 Javascript
    JavaScript中字符串分割函数split用法实例
    2015/04/07 Javascript
    AngularJS实现Model缓存的方式
    2016/02/03 Javascript
    Ajax验证用户名或昵称是否已被注册
    2017/04/05 Javascript
    Vue.js实现一个SPA登录页面的过程【推荐】
    2017/04/29 Javascript
    详解使用webpack构建多页面应用
    2017/12/21 Javascript
    javascript自定义日期比较函数用法示例
    2019/07/22 Javascript
    Vue2.0 实现页面缓存和不缓存的方式
    2019/11/12 Javascript
    vue父子组件间引用之$parent、$children
    2020/05/20 Javascript
    JavaScript封装单向链表的示例代码
    2020/09/17 Javascript
    jQuery实现电梯导航模块
    2020/12/22 jQuery
    python实现字符串连接的三种方法及其效率、适用场景详解
    2017/01/13 Python
    python3 发送任意文件邮件的实例
    2018/01/23 Python
    浅谈python可视化包Bokeh
    2018/02/07 Python
    Python paramiko模块的使用示例
    2018/04/11 Python
    python+opencv实现霍夫变换检测直线
    2020/10/23 Python
    django rest framework 实现用户登录认证详解
    2019/07/29 Python
    浅谈pycharm使用及设置方法
    2019/09/09 Python
    全球领先的全景影像品牌:Insta360
    2019/08/21 全球购物
    求网格中的黑点分布
    2013/11/06 面试题
    秋季运动会通讯稿
    2014/01/24 职场文书
    表彰会主持词
    2014/03/26 职场文书
    干货干货!2019最新优秀创业计划书
    2019/03/21 职场文书
    导游词之南京栖霞山
    2019/10/18 职场文书
    Python代码风格与编程习惯重要吗?
    2021/06/03 Python
    php双向队列实例讲解
    2021/11/17 PHP
    分析MySQL优化 index merge 后引起的死锁
    2022/04/19 MySQL
    Python pyecharts案例超市4年数据可视化分析
    2022/08/14 Python