欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

块级作用域和var,let,const的区别

程序员文章站 2024-01-03 08:45:28
...
一.块级作用域

块级作用域:在代码块内定义的变量在代码块外不能访问,代码块对变量有一个限制作用区域

二.使用var定义变量的缺陷
  • 2.1 没有块级作用域( 如 if 和 for的问题)
// 问题一
if(true){
   var name = "lxh";
   function fn() {
      console.log(name);
   }
}
console.log(name);      // lxh,可以访问内部变量name
fn();  // lxh
// 问题二: 用来计数的循环变量泄露为全局变量
var s = 'hello';
for (var i = 0; i < s.length; i++) {
   console.log(s[i]);    // h e l l o 
}
console.log(i); // 5
var btns = document.getElementsByTagName("button");
for (var i = 0; i < btns.length; i++) {
  btns[i].addEventListener("click",function () {
     console.log("第" + i + "个按钮被点击啦"); 
  })
}

点击每个按钮都输出第5个按钮被点击
块级作用域和var,let,const的区别
可以使用闭包来解决var没有块级作用域的问题

var btns = document.getElementsByTagName("button");
for (var i = 0; i < btns.length; i++) {
  (function(i) {
     btns[i].addEventListener("click", function () {
        console.log("第" + i + "个按钮被点击啦");
     })
  })(i);
}

此时就点击哪个按钮就会显示对应按钮索引

块级作用域和var,let,const的区别

  • 2.2 为什么闭包可以解决没有块级作用域的问题?
  • 因为函数有块级作用域!
三. let , var, const的区别
  • 3.1var 可以重复声明,后面的会覆盖前面的,let不允许重复声明,会报错
var name = "lxh";
var name = "bzx";
console.log(name);   // bzx
let age = 21;
let age = 18;
console.log(age); //Uncaught SyntaxError: Identifier 'age' has already been declared
  • 3.2 var存在变量提升,let没有(变量提升下次写)
  • 3.3 var声明的变量会绑定到window对象上,let不会
 var a = 666;
   var sum = 66;
   console.log(window.a);         //666
   console.log(window.sum);    //66
   
   let b = 20;
   const num = 30;
   console.log(window.b);         //undefined
   console.log(window.num);    //undefined
  • 3.4 let声明的变量支持块级作用域,var不支持
  • 3.5 const用于声明常量,const声明的值不可改变,且必须初始化
相关标签: ES6 let

上一篇:

下一篇: