代码部分
function foo(){
function bar(){
console.log("bar~ ~ ~")
}
return bar
}
var fn=foo();
fn();
【下面图解上述程序的执行流程】:
【1】:1 ~ 8 行全都扫描一遍
//创建GO对象;

//GO对象创建完成之后 , 就要执行代码了。
【2】:执行第7行代码
//函数一旦被执行 , 就要创建一个AO对象。

[3]:执行第8行代码
首先foo函数的执行上下文弹栈 , AO对象1也随之销毁。

//——第8行代码立即执行 ===》 创建函数应用上下文对象.
这个时候fn函数是指向0xb00的 , 所以创建的是BAR函数的执行上下文。

//——只有在调用函数的时候 , 才会创建一个AO对象。
本文通过一个具体的JavaScript函数示例,详细解析了函数从定义到执行的整个过程,包括GO对象和AO对象的创建机制,以及函数调用时的执行上下文栈管理。
1万+

被折叠的 条评论
为什么被折叠?



