JavaScript 的变量的全局作用域、局部作用域、块级作用域理解

导读:本篇文章讲解 JavaScript 的变量的全局作用域、局部作用域、块级作用域理解,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

1、全局变量

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

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

var lut = 520;
console.log(lut); // 520

2、局部变量

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

function lut() {
  var luzp = 410;
}
lut();
console.log(luzp);  // luzp is not defined  报错

 3、块级作用域

块级作用域:一对大括号就可以看成是一块,在这块区域中定义的变量,只能在这个区域中使用,但是在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

4、隐式全局变量

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

function lut() {

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

}

lut();

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

注意:

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

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

3、定义变量的时候尽量都使用 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 可被删除

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/66439.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!