你不知道的javascript(四)

提升

之前我们讲过var a = 2;后发生了什么,它回进行两个部分,第一部分是编译,而第二部分是执行。故应该是声明在前,赋值在后

a =2;

var  a;

console.log(a);//2

上面三行代码被这样执行:

var a ;

a = 2;

console.log(a);

but ...

console.log(a);//undefined

var a = 2;

上面两行怠慢会被这样执行:

var a ;

console.log(a);

a = 2;

这就是变量提升

只有声明本身会被提升,而赋值或其他运行逻辑会留在原地,接下来看下函数的提升

foo();

function foo(){

    console.log(a);//undefined

    var a =2 ;

}

foo可以被正常执行,因为它函数的声明被提升了,而且函数内部的变量提升不会超出函数范围,相当于如下代码:

function foo(){

    var a;

    console.log(a);//undefined

    a = 2;

}

foo();

but...

需要谨记的一点是函数声明可以被提升,但是函数表达式却不会被提升。

foo();//TypeError

var foo = function bar(){

  //

};

执行foo()在前,赋值在后,foo()由于对undefined值进行函数调用而导致非法错误,即使是具名的函数表达式,名称标识符在赋值之前也无法在所在作用域中使用:

foo();//TypeError

bar();//ReferenceError

var foo = function bar(){

}

实际上它是这样执行的:

var foo;

foo();

bar();

foo = function(){

   var bar = ...self...

}


函数优先

函数会首先被提升,然后才是变量。

       foo();//1
       var foo;
       function foo(){
       	  console.log(1);
       }
       foo = function(){
       	  console.log(2);
       }
实际上,是这样的:

      function foo(){
       	  console.log(1);
       }
       foo();
       foo = function(){
       	  console.log(a);
       }
再看:尽量避免在块内些函数声明。
       foo();//'b'
       var a = true;
       if(a){
       	  function foo(){
       	  	console.log('a');
       	  }
       }else{
       	  function foo(){
       	  	console.log('b');
       	  }
       }




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值