javascript痛点之一变量作用域

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript痛点之一变量作用域相关的知识,希望对你有一定的参考价值。

1.用var声明的变量是有作用域的,比如我们在函数中用var声明一个变量

1 ‘use strict‘;
2 function num(){
3   //用var声明一个变量num1
4    var num1 = 15;
5 }
 

函数中声明了一个变量num1,在js函数中用var声明变量实际上就声明了一个局部变量。局部变量就是在外部访问不到只能在函数内部访问

1  ‘use strict‘;
2  function num(){
3    //用var声明一个变量num1
4     var num1 = 15;
5  }
6  alert(num1);//num1 is not defined

2.在函数外定义变量的情况

 var num1 = 15;//var声明变量
 alert(num1);//15
 function add(){
    alert(num1+5);
 }
 add();//20
 

不在函数中定义的变量是全局变量,全局变量就是在任何地方都可以访问到

 

3.不使用var的情况

js允许变量不用声明就可以使用,不用var自动就是全局变量

num1 = 15;
alert(num1);//15

*但你最好不要这样做,如果引入多个js文件里面都有一个不用var声明的全局变量会污染全局,bug也不容易排查。使用严格模式‘use strict’则可避免这种情况

‘use strict’;
num1 = 15;//ReferenceError: num1 is not defined 会报错

 

4.两个函数内的变量互不影响

function num1(){
    var age = 15;
    alert(age);
}
num1()//15

function num2(){
    var age = 16;
    alert(age);
}
num2();//16;

 

函数内嵌套:内部函数可以访问外部函数的变量,而外部函数访问不了内部函数

function num(){
  var age =15;
  function num1(){
    var s = age+10;
     alert(s);//25
}
    alert(s+2);//会报错

}

 

如果是函数内的变量是重名的情况

function num(){
    var age = 15;
   
   function num1(){
     var age =20;
     alert(age);//20
}
 alert(age);//15
  num1();
}
num();

说明函数是从内而外查找的,当内部函数发现与外部函数重名就会自动屏蔽掉外部函数。

 

5.变量提升

变量可以先使用后声明

function num(){
   y = 5;
   alert(30+y);
  var y;

}
num();//35

对于上述函数num()javascript引擎看到的是

function num(){
 var y;

 y =5;

 alert(30+y);

}

只能对变量提升,变量初始化不可以提升

function num(){
   var y=5;
   alert(y+x);
   var x  = 30;
}
num();//NaN

要养成在函数中顶部先声明变量的好习惯!

在上面也说过了全局变量的概念

不在任何函数内定义的变量就是全局变量

js默认有一个全局对象window,全局作用域下的变量都是绑定到window的一个属性。

var  num = 15;
alert(num);//15
alert(window.num)//15

(完

 

下一章 javascript痛点之二作用域链

待续

 

以上是关于javascript痛点之一变量作用域的主要内容,如果未能解决你的问题,请参考以下文章

作用域是什么?

JS---闭包

前端之JS

JavaScript 作用域 与 作用域链

JavaScript 经典之一 闭包

作用域链