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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值