0

0

javascript如何声明变量_let和const有什么区别【教程】

幻影之瞳

幻影之瞳

发布时间:2026-01-22 17:48:10

|

820人浏览过

|

来源于php中文网

原创

必须用 let/const 而非 var,因 var 存在变量提升和函数作用域问题;let 具块级作用域且每次循环迭代创建新绑定;const 表示绑定不可重赋值,非值不可变,对象属性仍可修改。

javascript如何声明变量_let和const有什么区别【教程】

letconst 声明变量不是“更高级的写法”,而是必须理解其行为差异,否则很容易在闭包、循环或重赋值时出错。

为什么不能用 var 替代 let

var 存在变量提升(hoisting)和函数作用域问题,而 let 是块级作用域且不提升。最典型的坑是循环中绑定事件:

for (var i = 0; i < 3; i++) {
  setTimeout(() => console.log(i), 100); // 全部输出 3
}

换成 let 就正常:

for (let i = 0; i < 3; i++) {
  setTimeout(() => console.log(i), 100); // 输出 0, 1, 2
}
  • var 声明会被提升到函数顶部,i 实际只有一个绑定
  • let 每次迭代都创建新绑定,每个回调捕获的是各自作用域的 i
  • 即使没写 {}iffor 内部也是块级作用域

const 真的不能修改吗?

const 表示“绑定不可重新赋值”,不是“值不可变”。对象或数组本身仍可修改:

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载

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

const obj = { a: 1 };
obj.a = 2;        // ✅ 允许
obj.b = 3;        // ✅ 允许
obj = {};         // ❌ TypeError: Assignment to constant variable
  • 基本类型(stringnumberboolean)用 const 声明后确实不能改
  • 引用类型(ObjectArrayFunction)只能保证变量名不指向别的内存地址
  • 想真正冻结对象,得用 Object.freeze(),但它是浅冻结

什么时候该用 let,什么时候用 const

默认优先用 const,只有明确需要后续重新赋值时才换 let

  • 循环计数器(for (let i = 0; ...))、临时中间值(let temp = x * 2)→ 用 let
  • 配置项、DOM 元素引用、函数返回值、模块导入 → 统一用 const
  • 避免写 const x = ...; x = ...; 这种语法错误,编辑器通常会立刻报错
  • 团队协作中,const 能减少意外覆盖,比加注释更可靠

很多人以为 const 只是“声明常量”,其实它定义的是“不可重绑定的标识符”——这个语义细节决定了你在重构函数、提取变量或处理异步回调时会不会掉进作用域陷阱。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

367

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.30

java基础知识汇总
java基础知识汇总

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

1566

2023.10.24

if什么意思
if什么意思

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

846

2023.08.22

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

210

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

322

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

292

2025.06.11

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

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

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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