函数执行上下文

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==》赋值(实参列表),添加为执行上下文的属性
      03var定义的局部变量==undefined,,添加为执行上下文的属性
      04function声明的函数==》赋值fun,添加为执行上下文的属性
      05this==》(调用函数的对象)
   *执行全局代码

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);



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值