深入理解let、const和var

深入理解let、const和var

共同之处

在ES6以前,使用的是var​进行变量声明,在此之后,变量申明的方式多了let​和const

不同之处
  • 作用域var在当前函数作用域中有效,letconst在块级作用域中有效。
  • 变量提升var会变量提升并且可以访问,值为undefined,letconst有变量提升但是无法访问。
  • 重复声明var可以重复声明,letconst无法重复声明。
  • 声明初始化varlet可以不用初始化,const必须要初始化。
  • 值的可变性varlet声明的变量可以修改,const声明的变量不能修改本身的值,可以修改对象的属性和方法。
  • 挂载到window对象var声明的变量会挂载,letconst不会。
作用域不同

var​声明的变量存在执行上下文的变量环境 中,该环境在整个函数作用域中都是能够访问的。

let​和const​声明的变量存在执行上下文的词法环境 中,该环境在当前的块级作用域中才能被访问。

js 复制代码
{
  var a = 1;
  let b = 2;
  const c = 3;
  console.log(c); // 3
}
console.log(a); // 1
console.log(b); // ❌ 引用错误
console.log(c); // ❌ 引用错误
变量提升与暂时性死区

var​声明的变量在引用之后,是能够访问到变量的,只是这时候的变量获取到的是undefined​,这样的情况就是变量提升

let​和const​声明的变量在引用之后,是会报错的。虽然 let​ 和const​也被提升,但在声明之前访问会报错,这段不可访问的时间叫 暂时性死区

js 复制代码
console.log(a); // undefined(提升)
console.log(b); // 无法访问,暂时性死区
console.log(c); // 无法访问,暂时性死区
var a = 1;
let b = 2;
const c = 3;
重复声明

var可以重复进行声明,不会有问题;

let​和const在一个块级作用域下,只能进行一次声明。

js 复制代码
var x = 10;
var x = 20; // ✅ 

let y = 10;
let y = 20; // ❌

const z = 30;
const z = 40; // ❌
声明初始化

var​和let​在声明时可以不赋值,自动赋值为null;

const在声明时必须进行赋值,否则会报错。

js 复制代码
var a;  // 相当于 var a = null;
let b;  // 相当于 let b = null;
const c; // ❌ 报错。
值的可变性

var​和let​声明的变量值是可以重新赋值的,值是可变的

const​声明的变量值是不可以修改 的,如果赋值的是对象,对象内的属性和值是可以改变的。类似于常量

js 复制代码
var b = 1;
b = 2; // ✅ 可重新赋值

let a = 1;
a = 2; // ✅ 可重新赋值

const obj = { name: 'ErMao' };
obj.name = 'Da'; // ✅ 可修改对象内容
obj = {};        // ❌ 不可重新赋值
挂载在window对象上

var在全局作用域下声明的变量会挂在window对象上;

let​和const声明的变量不会挂在window对象上;

js 复制代码
var a = 1;
let b = 2;
const c = 3;
console.log(window.a) // 1
console.log(window.b) // undefined
console.log(window.c) // undefined
总结

ES6​以前,声明变量的时候会使用var​,会出现一些问题包括变量提升无法形成词法作用域 以及随意修改和声明 。出现let​和const​后,让JS的代码更加安全、更加简洁和更加规范

常见的差别有:作用域、变量提升、重复声明、声明初始化、值的可变性、是否会挂载在window对象上

在理解这一块知识前,最好先理解JS中的执行上下文 以及作用域 的相关知识,了解词法环境变量环境在执行上下文中的作用。

相关推荐
Awu122720 分钟前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪43 分钟前
Vue3-生命周期
前端
莪_幻尘1 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程
lichenyang4532 小时前
从 has.echo 到异步 API 注册表:一次 ASCF API 回调不触发的排查复盘
前端
林瞅瞅2 小时前
Nuxt3 项目部署 Nginx 防盗链后特定 JS 文件 403 问题修复方案
前端
kyriewen2 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
一颗奇趣蛋2 小时前
Web 视频开发完全指南:从入门到精通
前端
非洲农业不发达3 小时前
windows终端体验大升级,让你拥有macos级别的美化
前端·后端
妙码生花3 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十七):登录接口完善,登录页接口整合,解决跨域
前端·后端·ai编程
唐诗3 小时前
改 3 行配置,我的 Tauri dev 冷启动从 100 秒干到 4 秒
前端·客户端