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