【javaScript基础】执行上下文

栏目: JavaScript · 发布时间: 4年前

内容简介:执行上下文栈,也就是每个函数都有自己的执行环境。当进入一个执行环境时,该执行环境就会被推入一个环境栈中。而执行完当前执行环境,环境栈就会将当前执行环境弹出,把控制权返回给之前的执行环境。在环境栈弹出某个执行环境时,该环境会被销毁,包括保存在其中所有定义的变量和函数。全局执行环境直到应用退出才会被销毁,例如关闭网页或浏览器。

执行上下文栈,也就是 环境栈 。全局执行环境是最外围的一个执行环境。在Web浏览器中,全局环境被认为是window对象。

var a = 1; // 全局执行环境
function fn () {};
fn(); // fn执行环境
复制代码

每个函数都有自己的执行环境。当进入一个执行环境时,该执行环境就会被推入一个环境栈中。而执行完当前执行环境,环境栈就会将当前执行环境弹出,把控制权返回给之前的执行环境。

在环境栈弹出某个执行环境时,该环境会被销毁,包括保存在其中所有定义的变量和函数。全局执行环境直到应用退出才会被销毁,例如关闭网页或浏览器。

执行环境也叫执行上下文环境,环境栈也就是执行上下文栈。

【javaScript基础】执行上下文
var a = 3; // 1.进入全局上下文环境
var fn = function () {
    var b = 5;
    var y = bar(a + b); // 3.进入函数bar上下文环境
    console.log(y);
}
var bar = function (c) {
    return c;
}
fn(2); // 2.进入函数fn上下文环境
复制代码

1、在上述代码中,首先进入全局上下文环境。执行fn函数时,压栈并进入fn上下文环境。

2、在fn函数中,执行bar函数,压栈并进入bar执行环境。此时fn没有被销毁,因为还没执行结束。

3、bar函数执行结束,出栈并销毁bar上下文环境。回到fn执行环境。

4、fn函数执行完毕,出栈并销毁fn上下文环境。把控制权返回给全局上下文环境。

【javaScript基础】执行上下文

以上所述就是小编给大家介绍的《【javaScript基础】执行上下文》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JavaScript编程精解

JavaScript编程精解

Marijn Haverbeke / 徐涛 / 机械工业出版社华章公司 / 2012-10-1 / 49.00元

如果你只想阅读一本关于JavaScript的图书,那么本书应该是你的首选。本书由世界级JavaScript程序员撰写,JavaScript之父和多位JavaScript专家鼎力推荐。本书适合作为系统学习JavaScript的参考书,它在写作思路上几乎与现有的所有同类书都不同,打破常规,将编程原理与运用规则完美地结合在一起,而且将所有知识点与一个又一个经典的编程故事融合在一起,读者可以在轻松的游戏式......一起来看看 《JavaScript编程精解》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试