国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > web前端 > jscript > ECMA-262-3 深入解析.第四章.作用域链

ECMA-262-3 深入解析.第四章.作用域链

来源:程序员人生   发布时间:2014-03-16 04:11:13 阅读次数:2767次

导言

在第二章关于变量对象的描述中,我们已经知道一个执行上下文 (变量、函数声明和函数的形参)的数据作为属性存储在变量对象中。

同时我们也知道变量对象在每次进入上下文时创建,并填入初始值,值得更新出现在代码执行阶段。

这一章专门讨论与执行上下文直接相关的更多细节,这次我们将提及一个议题——作用域链

定义

如果要简要的描述并展示其重点,作用域链大多数与内部函数相关。

我们知道,ECMAScript 允许创建内部函数,我们甚至能从内部函数中返回这些函数。

var x = 10;function foo() {  var y = 20;  function bar() {    alert(x + y);  }  return bar;}foo()(); // 30

这样,很明显每个上下文拥有自己的变量对象 ,对于全局上下文,它是全局对象自身,对于函数,它是激活对象

作用域链完全是内部上下文所有变量对象(包括父变量对象)的列表。此链用来变量查询。即在上面的例子中,“bar”上下文的作用域链包括AO(bar)、AO(foo)和VO(global)。

但是,让我们仔细研究这个问题。

让我们从定义开始,并进深一步的讨论例子。

作用域链与一个执行上下文相关,变量对象的一条链标识符解析中用于变量查找。

一个函数上下文的作用域链在函数调用时创建包含激活对象和这个函数内部的[[scope]]属性。下面我们将更详细的讨论一个函数的[[scope]]属性。

在上下文中示意如下:

activeExecutionContext = {    VO: {...}, // or AO    this: thisValue,    Scope: [ // Scope chain      // list of all variable objects      // for identifiers lookup    ]};

这里scope定义如下:

Scope = AO + [[Scope]]

这种联合和标识符解析过程,我们将在下面讨论,这与函数的生命周期相关。

生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生