执行上下文

 console.log(a);  //undefined
  var a;

2)

console.log(a); //undefined
var a = 10;

3)

 f2(); //报错  :f2 is not a function
 var f2 = function(){};  //函数表达式
4)
console.log(this);  //widow
5)
console.log(f1);  //function f1(){}
function f1(){}  //函数声明

6)

console.log(num);//报错 num is not defined
num = 1;
从以上实例可看出 在javascript一句一句运行之前,浏览器会先把 变量 声明,而值为undefined,直到运行到变量赋值语句。与此类似的为 函数表达式 ,浏览器先只是把函数声明,赋值为undefined,因而调用f2函数应该放在函数表达式的后面。 this 函数声明 浏览器先声明并将整个函数赋值
                                   变量                                                    执行上下文
普通变量(包括函数表达式),如: var a = 10;
声明(默认赋值为undefined)
函数声明, 如: function fn() { }
声明并赋值
this
声明并赋值
变量的作用域:
函数在定义的时候(不是调用的时候),就已经确定了函数体内部自由变量的作用域,如下
二、函数声明和变量,谁先被提升
函数会首先被提升,然后才是变量
  console.log(foo);
  function foo(){
    console.log("函数声明");
  }
  var foo = "变量";


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值