js 执行上下文

2019-02-22  本文已影响0人  原型设计

1. 执行上下文:

Execution Content:函数执行前的准备工作

2. JS执行环境

* 全局作用域
* 函数作用域
* eval作用域(不推荐使用eval,暂时忽略)
* 块级作用域 ES6新增

3. JS是如何管理执行上下文?

通过栈(先进后出,后进先出的一种数据结构)的存取方式管理,称为"执行栈"或"调用栈"

4. 函数调用栈

js执行 最先进入全局环境,所以处于"栈底的永远是全局环境的执行上下文",出于"栈顶的是当前正在执行函数的执行上下文",当函数调用完成后,它就会从栈顶被推出去(出栈,闭包会阻止)

注意: 全局环境只有一个,对应的全局执行上下文也只有一个,只有当页面被关闭之后它才会从执行栈出栈,否则一直存在于栈底

5. 执行上下文的生命周期

1.创建阶段: 函数被调用时,进入函数环境,创建执行上下文。
2.执行阶段: 函数中的代码执行时,执行上下文进入执行阶段


创建阶段:
        1. 创建变量对象 
            
            1.1 Arguments 对象(已赋值)
            1.2 函数声明 (已赋值)
            1.3 变量声明,函数表达式声明(未赋值)
            
        2. 确定this (调用者确定)
        
        3. 确定作用域(词法环境决定)
        
执行阶段:
        1. 变量对象赋值
        
            1.1 变量赋值
            1.2 函数表达式赋值
        
        2. 调用函数
        
        3. 顺序执行其他代码

6. 变量对象和活动对象的区别?:

当进入到一个执行上下文后,这个变量对象才会被激活,所以叫活动对象(AO),这时候活动对象上的各种属性才能被访问。

注意:创建阶段对函数声明做赋值,变量及函数表达式仅做声明,真正的赋值操作要等到行上下文代码执行阶段

7.执行上下文的数量限制(堆栈溢出)

原文链接

上一篇 下一篇

猜你喜欢

热点阅读