javascript 函数的变量与作用域

函数内部变量的几种特别情况:

1、全局变量与局部变量

函数内部变量声明带var关键字:

1 function global(){
2      var name = "lilei"  //带var的变量声明,仍是局部变量,外部找不到
3 }
4 global();
5 console.log(name) //无法打印

函数内部变量声明不带var关键字:

1 function global(){
2     name = "lilei" //此时是全局变量
3 }
4 global();
5 console.log(name) //'lilei'

2、函数内部变量提升

1 function test(){
2     console.log(v);
3     var v = 1;
4 }
5 test(); //undefined

上述代码等同于 

1 function test(){
2     var v = undefined;
3     console.log(v);
4     v =1;
5         }
6 test()//undefiend

注意:变量声明会提升到函数顶部,但是变量赋值还是在原来的位置

3、函数作用域和变量声明提升的结合

var name = 'Nelsen'
function global(){
    console.log(name)
}
global(); //'Nelsen'

函数内部没有声明name,也没有初始化,此时函数会沿着作用域链查找到全局作用域,看是否有同名的变量声明,有则返回改初始化值

1 var name = 'Nelsen';
2 function global(){
3     console.log(name)
4     var name;
5 }
6 global(); //undefined

尽管此时函数外部也声明name并初始化,函数内部声明了name阻断了继续向外部查找同名变量,所以返回的是默认的undefined

3、javascript 引擎分析代码的三个步骤

 ①、声明并初始化参数,

 ②、声明局部变量,但不是初始化他们,

 ③、声明并初始化函数

//变量在声明之前是没有值的

1 var name = 'Nelsen';
2 function test2(){
3       console.log(name)
4       var name;
5 }
6 test2()  //undefined

但是如果变量作为参数传入,此时变量就有值了

1 var name = 'Nelsen';
2 function test2( name ){
3      console.log(name)
4      var name;
5 }
6 test2("Nelsen")    //Nelsen
原文地址:https://www.cnblogs.com/Nelsen8/p/7076745.html