js中代码有三种类型 : global , function , eval
每一种代码的执行都需要依赖自身的上下文环境
每种代码的执行(程序开始执行,函数被调用,eval代码执行)都会产生一个新的上下文环境,这个上下文环境就称为执行上下(execution context--EC)
执行上下文可以抽象的认为是一个Object,具有一系列属性,其大体结构如下:
Execution Context : { variable object : [vars,function declaration,arguments,...] scope chain : [variable object,all parent scopes] this : context object }
变量对象(variable object)
变量对象的抽象表示:
VO : { var1 : xxx, var2 : xxx, var3 : <function> }
变量对象用于存储定义在上下文中的变量(vars) 和 函数声明(function declaration) ---函数表达式不包含在内
函数与global和eval稍有不同,在函数上下文中,变量对象被表示为活动对象(activation object)
活动对象(activation object)
活动对象是函数上下文中的变量对象,函数被激活时被创建,活动对象拥有变量对象的属性,除此之外,活动对象还包含了特殊对象arguments,抽象表示为:
AO : { var1 : xxx, var2 : xxx, var3 : <function>, arguments : {0:xxx,1:xxx} }
作用域链(scope chain)
作用域链是一个对象列表,用来检索上下文中出现的标识符(identifiers) ---标识符可以认为是变量,函数声明或者函数中的参数
通常情况下,作用域链包括自身变量对象或活动对象,父级变量对象(try和with语句会产生临时作用域对象,导致作用域变更)
This指针
this是执行上下文的一个属性,不是某个变量对象的属性.
this的值直接从执行上下文中获取,而不会从作用域链中搜寻。也就是说this的值只取决于进入上下文时的情况。所以,this是不允许赋值的