码迷,mamicode.com
首页 > Web开发 > 详细

js的执行上下文

时间:2016-07-13 13:36:49      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:


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是不允许赋值的

js的执行上下文

标签:

原文地址:http://www.cnblogs.com/just4play/p/5666395.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!