0

0

JavaScript 变量声明:var, let 与 const 的区别详解

夢幻星辰

夢幻星辰

发布时间:2025-11-17 22:29:33

|

1034人浏览过

|

来源于php中文网

原创

var为函数作用域且存在变量提升,let和const为块级作用域并有暂时性死区;const声明不可重新赋值的常量,let用于可变变量,推荐优先使用const和let,避免var。

javascript 变量声明:var, let 与 const 的区别详解

在 JavaScript 中,varletconst 都是用来声明变量的关键字,但它们的行为和作用域规则有显著不同。理解这些差异对编写安全、可维护的代码至关重要。

作用域差异

变量的作用域决定了它在代码中的可访问范围。

  • var 声明的变量具有函数作用域或全局作用域。如果在函数内使用 var 声明,变量只在该函数内部有效;若在函数外声明,则为全局变量。
  • letconst 具有块级作用域(block scope),也就是用大括号 {} 包裹的代码块内有效,比如 if 语句、for 循环中。

例如:

if (true) {
  var a = 1;
  let b = 2;
}
console.log(a); // 输出 1
console.log(b); // 报错:b is not defined

因为 var 不受块级作用域限制,而 let 受限于块作用域。

立即学习Java免费学习笔记(深入)”;

变量提升与暂时性死区

var 存在变量提升(hoisting),即变量声明会被提升到作用域顶部,但赋值不会。访问未初始化的 var 变量会得到 undefined。

console.log(x); // undefined
var x = 10;

letconst 也有提升,但进入作用域后不会立即初始化,从作用域开始到被声明之前,处于“暂时性死区”(Temporal Dead Zone, TDZ)。在此区域内访问变量会抛出错误。

Chromox
Chromox

Chromox是一款领先的AI在线生成平台,专为喜欢AI生成技术的爱好者制作的多种图像、视频生成方式的内容型工具平台。

下载
console.log(y); // 报错:Cannot access 'y' before initialization
let y = 20;

重复声明与重新赋值

var 允许在同一作用域内重复声明同一个变量,不会报错。

var name = "Alice";
var name = "Bob"; // 合法

let 在同一作用域内不允许重复声明,否则会抛出语法错误。

let age = 25;
let age = 30; // 报错:Identifier 'age' has already been declared

const 声明的变量必须在声明时初始化,且不能重新赋值。

const PI = 3.14;
PI = 3.15; // 报错:Assignment to constant variable.

注意:const 并不保证值的不可变性。对于对象或数组,可以修改其属性或元素。

const user = { name: "Tom" };
user.name = "Jerry"; // 合法
user = {}; // 报错:不能重新赋值

适用场景建议

现代 JavaScript 开发中推荐优先使用 const,除非你需要重新赋值,这时使用 let。避免使用 var,因为它容易引发意料之外的问题,如作用域泄漏、变量覆盖等。

  • const 声明常量、函数、对象、数组等不需要重新赋值的变量。
  • let 声明需要在后续修改值的变量,如循环计数器、累加器等。
  • 尽量不要用 var,特别是在新项目中。

基本上就这些。掌握 var、let 和 const 的区别,能帮助你写出更清晰、更安全的 JavaScript 代码。不复杂但容易忽略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

95

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

106

2025.09.18

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6475

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3339

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1680

2025.12.25

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
走进 ES6 新标准语法
走进 ES6 新标准语法

共15课时 | 1.6万人学习

React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号