js中的执行上下文

1.代码分为全局代码和函数(局部)代码。
2.全局执行上下文
在执行全局代码前将window确定为全局执行上下文。
对全局数据进行预处理
var定义的全局变量===>undefined,添加为window的属性
function声明的全局函数===>赋值fun,添加为window方法
this===>赋值(window)
开始执行全局代码
3.函数上下文的执行
在调用函数时,准备执行函数体之前,创建对应的函数执行上下文对象
对局部的数据进行预处理
形参变量==>赋值(实参)==>添加为执行上下文的属性
arguments–>赋值(实参列表),添加为执行上下文的属性
var定义的局部变量–>undefined,添加为执行上下文的属性
function申明的函数–>赋值(fun),添加为执行上下文的方法
this–>赋值(调用函数的对象)
开始执行函数体代码

//全局执行上下文
console.log(a1,window.a1);
 a2();
 console.log(this);
 var a1 =  3;
 fucntion a2(){
	console.log('a2');
}
console.log(a1);
// 函数执行上下文
function fn(a1){
	console.log(a1);//2
	console.log(a3);//undefined
	a4();//a4()
	console.log(this);//window
	console.log(arguments);//伪数组(2,3)
	var a3 = 3;
	function a4(){
	console.log('a4');
	}
}
fn(2,3);//要执行才会创建空间
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值