JS 变量提升、执行上下文、作用域链
JS 变量提升、执行上下文、作用域链
一、执行上下文(execute context)EC
理解:代码的执行环境
时机:代码正式执行之前会进入到执行环境,代码执行结束销毁
工作:
1.创建变量对象
(1)变量
(2)函数及函数的参数
(3)全局:window
(4) 局部:抽象的但是确实存在
2.确认this指向
(1)全局:this ---> window
(2) 局部:this----> 调用其的对象
3.创建作用域链
当前变量对象+父级作用域链+。。。
4.扩展:
ECObj = {
变量对象:{变量,函数,函数的形参},
scopechain:父级作用域链 + 当前的变量对象,
this:{window || 调用其的对象}
}
二、 作用域链:上下文中代码执行时会创建变量对象的一个作用域链。
作用域链决定者各级上下文中代码访问变量和函数的顺序。
代码正在执行的上下文的变量对象始终位于作用域链的最前端。
作用域链的下一个变量对象来自包含上下文,再下一个变量对象来自下一个包含上下文。
以此类推直至全局上下文,全局上下文的变量对象始终是作用域链的最后一个变量对象。
作用域链增强:执行上下文主要有全局上下文和函数上下文两种(eval()调用内部存在第三种上下文),
但有其他方式来增强作用域链。某些语句会导致在作用域链前端临时添加一个上下文,
这个上下文在代码执行后会被删除 。
(1)try/catch语句的catch块
(2)with语句
漫思