代码分类
全局代码
函数(局部)代码
全局执行上下文
在执行全局代码前将window确定为全局执行上下文
对全局数据进行预处理
var定义的全局变量==>undefined,添加为window的属性
function声明的全局函数==>赋值(fun),添加为window的方法
this==>赋值(window)
开始执行全局代码
函数执行上下文
在调用函数,准备执行函数体之前,创建对应的函数执行上下文
对局部数据进行预处理
形参变量==>赋值(实参)==>添加为执行上下文的属性
arguments==>赋值(实参列表)==>添加为执行上下文的属性
var定义的局部变量==>undefined,添加为执行上下文的属性
function声明的函数==>赋值(fun)==>添加为执行上下文的方法
this==>赋值(调用函数的对象)
开始执行函数体代码
1 | //函数执行上下文 注意:是在调用函数时创建的 |
执行上下文栈
在全局代码执行前,js引擎就会创建一个栈来存储管理所有的执行上下文对象
在全局执行上下文(window)创建后,将其添加到栈中(压栈)
在函数执行上下文创建后,将其添加到栈中(压栈)
在当前函数执行完后,将栈顶的对象移除(出栈)
当所有的代码执行完后,栈中只剩下window
1 | var a=10 |
1 | console.log('global begin: '+i) //undefined |