前端开发中执行上下文的示例分析

  介绍

这篇文章将为大家详细讲解有关前端开发中执行上下文的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

前端开发中执行上下文的示例分析“> <br/> </p> <p class=先随便放张图

我们在JS学习初期或者面试的时候常常会遇到考核变量提升的思考题。比如先来一个简单一点的。

console.log (a),,,,//,这里会打印出什么?   var  a =, 20;

暂时先不管这个例子,我们先引入一个JavaScript中最基础,但同时也是最重要的一个概念<强>执行上下文(执行上下文)

每次当控制器转到可执行代码的时候,就会进入一个执行上下文。执行上下文可以理解为当前代码的执行环境,它会形成一个作用域.JavaScript中的运行环境大概包括三种情况。

<李>

全局环境:JavaScript代码运行起来会首先进入该环境

<李>

函数环境:当函数被调用执行时,会进入当前函数中执行代码

<李>

eval

因此在一个JavaScript程序中,必定会产生多个执行上下文,在我的上一篇文章中也有提到,JavaScript引擎会以堆栈的方式来处理它们,这个堆栈,我们称其为函数调用栈(调用堆栈)。栈底永远都是全局上下文,而栈顶就是当前正在执行的上下文。

当代码在执行过程中,遇到以上三种情况,都会生成一个执行上下文,放入栈中,而处于栈顶的上下文执行完毕之后,就会自动出栈,为了更加清晰的理解这个过程,根据下面的例子,结合图示给大家展示。

var  color =, & # 39;蓝# 39;;      function  changeColor (), {   ,,,var  anotherColor =, & # 39;红色# 39;;      ,,,function  swapColors (), {   ,,,,,,,var  tempColor =, anotherColor;   ,,,,,,,anotherColor =,颜色;   ,,,,,,,color =, tempColor;   ,,,}      ,,,swapColors ();   }      changeColor();

我们用ECStack来表示处理执行上下文组的堆栈。我们很容易知道,第一步,首先是全局上下文入栈。

前端开发中执行上下文的示例分析

第一步:全局上下文入栈

全局上下文入栈之后,其中的可执行代码开始执行,直到遇到了changeColor(),这一句激活函数changeColor创建它自己的执行上下文,因此第二步就是changeColor的执行上下文入栈。

前端开发中执行上下文的示例分析

第二步:changeColor的执行上下文入栈

changeColor的上下文入栈之后,控制器开始执行其中的可执行代码,遇到swapColors()之后又激活了一个执行上下文。因此第三步是swapColors的执行上下文入栈。

前端开发中执行上下文的示例分析

第三步:swapColors的执行上下文入栈

在swapColors的可执行代码中,再没有遇到其他能生成执行上下文的情况,因此这段代码顺利执行完毕,swapColors的上下文从栈中弹出。

前端开发中执行上下文的示例分析

第四步:swapColors的执行上下文出栈

swapColors的执行上下文弹出之后,继续执行changeColor的可执行代码,也没有再遇到其他执行上下文,顺利执行完毕之后弹出。这样,ECStack中就只身下全局上下文了。

前端开发中执行上下文的示例分析

第五步:changeColor的执行上下文出栈

全局上下文在浏览器窗口关闭后出栈。

注意:函数中,遇到return能直接终止可执行代码的执行,因此会直接将当前上下文弹出栈。

前端开发中执行上下文的示例分析

前端开发中执行上下文的示例分析