1.代码分类(位置)
*全局代码
*局部代码
2.全局执行上下文
console.log(a1); //window.a1
console.log(a2); //window.a2
window.a2();
console.log(this); //window
var a1=3;
function a2(){
console.log('a2');
}
*在执行全局代码前将window确定为全局执行上下文
*对全局数据进行预处理
:var 定义的全局变量,添加为window的属性
:function声明的全局函数 赋值fun 添加为window的方法
:this=>赋值 window
*执行全局代码
3.函数执行上下文
*在调用函数,准备执行函数体之前,创建对应的函数执行上下文对象
*对局部函数进行预处理
01:形参变量==》赋值(实参列表),添加为执行上下文的属性
02:arguments==》赋值(实参列表),添加为执行上下文的属性
03:var定义的局部变量==》undefined,,添加为执行上下文的属性
04:function声明的函数==》赋值fun,添加为执行上下文的属性
05:this==》(调用函数的对象)
*执行全局代码
function fn(a1){
console.log(a1); //2
console.log(a2); //undefined
a3(); //a3();
console.log(this); //window
//类数组/伪数组
console.log(arguments); //2,3
var a2=3;
function a3(){
console.log('a3()');
}
}
fn(2,3);
函数执行上下文
于 2022-09-18 15:04:26 首次发布