1. JavaScript可执行代码
JavaScript可执行代码有三种:
- 全局代码
- 函数代码
- eval代码
2. 执行上下文栈
在js执行到一个函数的时候,就会进行执行上下文(execution context)的准备。
执行上下文栈(Execution context stack,ECS)用于管理执行上下文。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
| ECStack = [globalContext] // 执行上下文栈的底部永远有个globalContext
function fun3() { console.log('fun3') }
function fun2() { fun3(); }
function fun1() { fun2(); }
fun1();
↓
// fun1() ECStack.push(<fun1> functionContext);
// fun1中调用了fun2,还要创建fun2的执行上下文 ECStack.push(<fun2> functionContext);
// fun2中调用了fun3! ECStack.push(<fun3> functionContext);
// fun3执行完毕 ECStack.pop();
// fun2执行完毕 ECStack.pop();
// fun1执行完毕 ECStack.pop();
// javascript接着执行下面的代码,但是ECStack底层永远有个globalContext
|
每次在调用函数前,都会将函数执行需要的执行上下文入栈,在函数结束执行之后,会出栈。