小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。
作用域的理解
作用域分为全局作用域、局部作用域和块级作用域,下面通过几个小的例子分别进行解释。
全局变量:其他任何位置使用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 可被删除