Für uns Frontend-Entwickler ist es notwendig, den internen Ausführungsmechanismus des JS
-Programms zu verstehen. Eines der Schlüsselkonzepte ist der Ausführungskontext und der Ausführungsstapel von Js. Der Ausführungskontext ist das untergeordnete Wissen der <code>JS
-Sprache. Das Erlernen und Beherrschen dieser Sprache wird uns helfen, die Essenz der JS
-Sprache besser zu verstehen, und es wird uns auch helfen Umfang und Abschluss, variable Beförderung und andere damit verbundene Kenntnisse verstehen. JS
程序内部执行机制是必要的,其中一个关键概念就是Js
的执行上下文和执行栈。执行上下文是JS
语言较为底层的知识,学习掌握有助于我们更深入的把握JS
这门语言的本质,也有助于理解作用域、闭包、变量提升等相关知识。
代码执行前,浏览器的Js
引擎先会创建代码执行的环境来处理此Js
代码的转换和执行,代码的执行环境称为执行上下文。
执行上下文是一个抽象概念,包含当前正在运行的代码以及帮助其执行的所有内容。
执行上下文主要分为三类:
Eval
执行上下文 —— 运行在Eval
函数中代码时创建的环境,Eval
由于性能问题在我们平时开发中很少用到,所有这里我们不在讨论。接下来我们重点来讲全局上下文和函数上下文。
2.1 全局执行上下文
当我们的JS
文件跑起来之后,首先创建的就是全局执行上下文。
当我们的文件里没有一行代码时,全局执行上下文中比较干净,只有两个东西。
Window
,Node
环境下是Global
)this
变量(指向的还是全局对象)这时候如果我们在文件里写点东西,比如我写如下代码:
var name = '小明' var age = 18 function showName(){ return { name : name, age : age } }
全局执行上下文就会立刻变成这个样子:
上图可以看到,我们明明给name
和age
赋值了,咋还会显示undefined
呢?这是因为执行上下文分为两部分,创建阶段和执行阶段。
以上就是创建阶段的全局上下文概况,在创建阶段JS
引擎将会做以下几件事:
window
作为全局执行上下文对象this
,this
指向window
undefined
,函数声明放入内存接下来才会进入了全局执行上下文的执行阶段,也就是赋值阶段,如下图:
需要注意的是执行上下文执行阶段是一行一行执行的,如下图所示:
2.2 函数执行上下文
理解完全局执行上下文,函数执行上下文也我们只需要关注它与全局上下文之间的不同即可,两者之间不同主要表现在以下三个方面:
window
作为全局对象,而是函数执行上下文则是创建参数对象arguments
;创建的this
也不会指向全局对象,而是取决于函数是如何调用的。我们通过下面这个例子来看函数上下文不同阶段的表现:
var name = '小明' var age = 18 function showName(){ return { name : name, age : age } } // 调用该函数 showName()
当我们调用showName
Js
-Engine des Browsers zunächst eine Codeausführungsumgebung, um diese Js
zu verarbeiten Die Konvertierung und Ausführung von Code sowie die Ausführungsumgebung des Codes werden als Ausführungskontext bezeichnet. Ausführungskontext ist eine Abstraktion, die den Code
umfasst, der geradeläuft, und alles
zu seiner Ausführung beiträgt🎜. 🎜Eval
-Ausführungskontext – die Umgebung, die beim Ausführen des Codes in der Eval
-Funktion erstellt wird, wird in unserem nicht verwendet Code aufgrund von Leistungsproblemen wird in der täglichen Entwicklung selten verwendet, daher werden wir hier nicht darauf eingehen. JS
-Datei ausgeführt wird, wird als Erstes der globale Ausführungskontext erstellt . 🎜🎜Wenn unsere Datei keine Codezeile enthält, ist der globale Ausführungskontext relativ sauber und enthält nur zwei Dinge. 🎜Window
im Browser, Global
in der Node
-Umgebung)function testA(){ console.log('执行第一个测试函数的逻辑'); testB(); console.log('再次执行第一个测试函数的逻辑'); } function testB(){ console.log('执行第二个测试函数的逻辑'); } testA()
name
und age
eindeutig Werte zugewiesen, aber warum ist undefiniert?
immer noch angezeigt? Dies liegt daran, dass der Ausführungskontext in zwei Teile unterteilt ist: die Erstellungsphase und die Ausführungsphase. 🎜JS
-Engine Folgendes aus: 🎜window
als globales Ausführungskontextobjekt this
, this
zeigt auf window
undefiniert
, Funktionsdeklaration wird im Speicher platziertwindow
als globales Objekt, aber der Funktionsausführungskontext verwendet das Parameterobjekt arguments
, das erstellt hat Auch this
zeigt nicht auf das globale Objekt, sondern hängt davon ab, wie die Funktion aufgerufen wird. showName
aufrufen, beginnen wir mit der 🎜Erstellung von Der Funktionsausführungskontext In Phase 🎜 ist die Szene des Funktionsausführungskontexts wie folgt: 🎜🎜🎜🎜🎜 Dann wird in dieser Phase der Code in der Funktion Zeile für Zeile ausgeführt Da beispielsweise keine Änderung der beteiligten Variablen erfolgt, bleibt der Inhalt des Funktionskontexts unverändert, und nach Abschluss der Ausführung endet der Lebenszyklus des Funktionskontexts. 🎜当我们调用showName
函数时,在浏览器中运行状况:
我们看到当函数执行完后,其对应的执行上下文也随之消失了。这个消失的过程,我们叫它出栈——在JS
代码执行过程中,JS
引擎会为我们创建“执行上下文栈”。
在全局代码执行前,JS
引擎为了管理执行上下文,确保程序的执行顺序。JS
引擎会创建一个栈来管理所有的所有的执行上下文对象。
因为函数上下文可能会存在多个,我们不可能保留所有的上下文。当一个函数执行完毕,其对应的上下文必须让出之前所占用的资源。因此上下文的建立和销毁,就对应了一个” 入栈 “和” 出栈 “的操作。
当我们调用一个函数的时候,就会把它的上下文推入调用栈里,执行完毕后出栈,随后再为新的函数进行入栈操作。
我们通过一个例子来看一下这个过程:
function testA(){ console.log('执行第一个测试函数的逻辑'); testB(); console.log('再次执行第一个测试函数的逻辑'); } function testB(){ console.log('执行第二个测试函数的逻辑'); } testA()
1、执行之前,全局上下文创建:
2、testA
调用,testA
对应函数上下文创建:
3、testB
调用,testB
对应函数上下文创建:
4、testB
执行完毕,对应上下文出栈,剩下testA
和全局执行上下文:
5、testA
执行完毕,对应执行上下文出栈,此时只剩下全局上下文:
在这整个过程里,调用栈的变化示意如下:
执行上下文是什么:代码执行前,Js引擎会创建代码的执行环境,代码的执行环境称作执行上下文,包含当前正在运行的代码以及帮助其执行的所有内容。
全局执行上下文:(1)将window作为全局执行上下文对象(2)创建this,this 指向window(3)给变量和函数安排内存空间(4)变量赋值undefined,函数声明放入内存(5)放入作用域链
全局与函数执行上下文不同:(1)全局:在文件执行前创建;函数:在函数调用时创建(2)全局:只创建一次;函数:调用几次创建几次(3)将window作为全局对象;函数:创建参数对象arguments,this指向调用者
执行栈:管理所有的执行上下文对象
【相关推荐:javascript视频教程、编程基础视频】
Das obige ist der detaillierte Inhalt vonIn einem Artikel werden der Ausführungskontext und der Ausführungsstapel in JavaScript (eine Kombination aus Bildern und Text) ausführlich erläutert.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!