作用域的理解

320 阅读2分钟

小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。

作用域的理解

作用域分为全局作用域、局部作用域和块级作用域,下面通过几个小的例子分别进行解释。

全局变量:其他任何位置使用var声明的的变量,函数除外,那么这个变量就是全局变量,全局变量可以在页面的任何位置使用,即全局作用域。

全局变量,如果页面不关闭,那么变量所占用的内存就不会释放,就会占空间,消耗内存。

var lut = 520;

console.log(lut); // 520

局部变量:在函数内部定义的变量,是局部变量,外面不能使用,即局部作用域。

function lut() {

var luzp = 410;

}

lut();

console.log(luzp); // luzp is not defined 报错

块级作用域:一对大括号就可以看成是一块,在这块区域中定义的变量,只能在这个区域中使用,但是在js中在这个块级作用域中定义的变量,外面也能使用。

说明:js没有块级作用域,只有函数除外

{

var lut = 520;

console.log(lut); // 520

}

console.log(lut);

if(true){

var lut = 1314;

}

console.log(lut);

for(var i = 0;i < 5; i++){

var lut = 520;

}

console.log(lut); // 520

var i = 0;

while (i < 5){

var lut = 1314;

i++;

}

console.log(lut); // 1314

隐式全局变量:声明的变量没有var,就叫隐式全局变量

function lut() {

date = 410;//是隐式全局变量

}

lut();

console.log(date); // 410 函数运行结束还可以访问

全局变量是不能被删除的,隐式全局变量是可以被删除的

定义变量使用var是不会被删除的,没有var是可以删除的

var luzp = 27;

lut = 23;

delete luzp;//把luzp删除了

delete lut;//把lut删除了

console.log(typeof luzp); number 不能被删除

console.log(luzp+10); // 37

console.log(typeof lut); // undefined 可被删除