从0开始学习JavaScript--JavaScript 中 `let` 和 `const` 的区别及最佳实践

在JavaScript中,let 和 const 是两个用于声明变量的关键字。尽管它们看起来很相似,但它们之间有一些重要的区别。本篇博客将深入探讨 let 和 const 的用法、区别,并提供一些最佳实践,以确保在代码中正确使用它们。
let 和 const 的基本用法
let 的基本用法
let 声明一个变量,并在之后重新赋值。它具有块级作用域,适用于那些需要在程序执行过程中改变的变量。
let count = 10;if (true) {let count = 20; // 块级作用域console.log(count); // 输出: 20
}console.log(count); // 输出: 10
在这个例子中,let 关键字在不同的块中使用相同的变量名 count,而不会互相干扰。
const 的基本用法
const 用于声明一个常量,其值在声明后不能被修改。它同样也具有块级作用域。
const pi = 3.14;if (true) {const pi = 3.1415926535; // 块级作用域console.log(pi); // 输出: 3.1415926535
}console.log(pi); // 输出: 3.14
在这个例子中,尝试修改 pi 的值会导致错误。const 常用于声明不应该被重新赋值的常量,例如数学常数、配置值等。
区别和注意事项
1. 变量重新赋值
let 允许变量重新赋值,而 const 不允许。
let x = 10;
x = 20; // 合法const y = 30;
y = 40; // 报错: Assignment to constant variable
使用 const 声明的变量在声明后不能再次赋值,这有助于确保常量的不可变性。
2. 块级作用域
let 和 const 都具有块级作用域,这意味着它们在 {} 内声明的变量只在该块中可见。
{let blockScoped = 'I am a block scoped variable';const alsoBlockScoped = 'I am also a block scoped variable';
}console.log(blockScoped); // 报错: blockScoped is not defined
console.log(alsoBlockScoped); // 报错: alsoBlockScoped is not defined
在这个例子中,blockScoped 和 alsoBlockScoped 变量只在 {} 内部可见,尝试在外部访问会导致错误。
3. 提升
let 和 const 都不会被提升到作用域的顶部。它们在声明语句之前是不可访问的。
console.log(a); // 报错: Cannot access 'a' before initialization
let a = 5;console.log(b); // 报错: Cannot access 'b' before initialization
const b = 10;
在这个例子中,尝试在声明语句之前访问变量 a 和 b 会导致错误。
最佳实践
1. 优先使用 const
在编写代码时,尽量使用 const 来声明变量。这有助于确保变量不会被意外地重新赋值,从而提高代码的可维护性。
// 不好的实践
let radius = 10;
let pi = 3.14;
let area = pi * radius * radius;// 好的实践
const radius = 10;
const pi = 3.14;
const area = pi * radius * radius;
2. 使用 let 仅在需要重新赋值时
如果确实需要在后续代码中重新赋值,才使用 let。这可以使代码更易于理解,因为读者会知道这个变量可能会在后续的代码中发生变化。
// 不好的实践
const totalPrice = calculateTotalPrice();
let discount = 0;if (userIsPremium()) {discount = 0.2;
}const finalPrice = totalPrice - (totalPrice * discount);// 好的实践
const totalPrice = calculateTotalPrice();
let discount = userIsPremium() ? 0.2 : 0;
const finalPrice = totalPrice - (totalPrice * discount);
在这个例子中,discount 变量只在用户是高级用户时才会改变,因此使用 let 是合适的。
3. 使用 const 避免不必要的变量
避免使用 let 来声明不必要的变量。使用 const 声明的常量更容易被理解,而且它们的不可变性可以提高代码的可靠性。
// 不好的实践
let temp = 0;
let counter = 0;while (counter < 10) {temp += counter;counter++;
}// 好的实践
const temp = Array.from({ length: 10 }, (_, index) => index).reduce((acc, val) => acc + val, 0);
在这个例子中,使用 const 和函数式编程的方法更清晰地表达了代码的目的。
总结
在JavaScript中,let 和 const 是两个关键字,用于声明变量。let 允许变量重新赋值,适用于需要在程序执行过程中改变的变量,而 const 用于声明常量,其值在声明后不可修改。最佳实践中,建议优先使用 const,以确保变量不被意外地重新赋值,提高代码的可维护性。使用 let 仅在确实需要在后续代码中重新赋值时,避免不必要的变量。通过正确使用这两个关键字,我们可以编写出更具可读性、可维护性和稳健性的JavaScript代码。总体而言,let 和 const 的灵活运用有助于提高代码的可靠性和清晰度,为JavaScript开发提供了更好的编程体验。
相关文章:
从0开始学习JavaScript--JavaScript 中 `let` 和 `const` 的区别及最佳实践
在JavaScript中,let 和 const 是两个用于声明变量的关键字。尽管它们看起来很相似,但它们之间有一些重要的区别。本篇博客将深入探讨 let 和 const 的用法、区别,并提供一些最佳实践,以确保在代码中正确使用它们。 let 和 const …...
【上海大学数字逻辑实验报告】二、组合电路(一)
一、 实验目的 熟悉TTL异或门构成逻辑电路的基本方式;熟悉组合电路的分析方法,测试组合逻辑电路的功能;掌握构造半加器和全加器的逻辑测试;学习使用可编程逻辑器件的开发工具 Quartus II设计电路。 二、 实验原理 异或门是数字…...
lodash中foreach踩坑
什么是lodash Lodash 是一个 JavaScript 实用工具库,提供了很多用于处理数据、简化开发等方面的功能。它提供了一组常用的工具函数,用于处理数组、对象、字符串等常见数据结构,同时也包含了一些函数式编程的工具。对于前端开发来说ÿ…...
Unity C++交互
一、设置Dll输出。 两种方式: 第一:直接创建动态链接库工程第二:创建的是可执行程序,在visual studio,右键项目->属性(由exe改成dll) 二、生成Dll 根据选项Release或Debug,运行完上面的生成解决方案后…...
人工智能-优化算法之动量法
对于嘈杂的梯度,我们在选择学习率需要格外谨慎。 如果衰减速度太快,收敛就会停滞。 相反,如果太宽松,我们可能无法收敛到最优解。 泄漏平均值 小批量随机梯度下降作为加速计算的手段。 它也有很好的副作用,即平均梯度…...
【MySQL】InnoDB中的索引
目录标题 索引底层的数据结构:B树B树与B树的区别InnoDB与MyISAM在B树使用索引结构的不同? 聚簇索引非聚簇索引联合索引 B树索引适用的条件查询全值匹配匹配左边的列匹配列前缀匹配范围的值精确匹配某一列并范围匹配另外一列避免使用隐式转换 排序必须按照…...
《软件工程原理与实践》复习总结与习题——软件工程
软件生命周期 软件生命周期分为三个时期、八个阶段 软件定义时期: 1)问题定义阶段:要解决什么问题 2)可行性研究阶段:确定软件开发可行 3)需求分析阶段:系统做什么 软件开发时期:…...
软工2021上下午第六题(组合模式)
阅读下列说明和Java代码,将应填入(n)处的字句写在答题纸的对应栏内。 【说明】 层叠菜单是窗口风格的软件系统中经常采用的一种系统功能组织方式。层叠菜单中包含的可能是一个菜单项(直接对应某个功能),也可…...
在Spring Boot中使用不同的日志
前言,本篇就是介绍在Java中使用相关的日志,适合初学者看,如果对这篇不感兴趣的可以移步了,本篇主要围绕我们Java中的几种日志类型,也说不上有多深入,算的上浅入浅出吧,如果你有一段时间的开发经…...
运维知识点-openResty
openResty 企业级实战——畅购商城SpringCloud-网站首页高可用解决方案-openRestynginxlua——实现广告缓存测试企业级实战——畅购商城SpringCloud-网站首页高可用解决方案-openRestynginxlua——OpenResty 企业级实战——畅购商城SpringCloud-网站首页高可用解决方案-openRes…...
微服务中配置Nacos热更新
启动Nacos startup.cmd -m standalone 在IDE中启动服务 打开nacos管理后台并选择配置列表 创建配置(这里以日期格式为例) 因为这里配置的是userservice的服务,所以在userservice服务的pom文件中引入依赖 配置一个bootstrap.yml文件 注意这里bootstrap文件中配置过的内容,在app…...
ABAP2XLSX 的安装和demo
ABAP2XLSX 是一个git上面的很好用的工具,它可以帮助abaper们更方便,更简单的生成各种各样复杂的自定义的excel,以满足各企业的信息化建设 在安装这个之前,请先查看之前的博客,去安装abapgit abap2xlsx地址࿱…...
记一篇Centos7安装innodb_ruby
安装innodb_ruby过程非常坎坷,这里记录下安装过程,有些坑当时没有记录下来,主要把完成安装过程就记录下来 yum安装ruby默认的会安装ruby2.0.0版本,但是在安装innodb_ruby时,会报错,提示至少需要2.4版本以上…...
VMware虚拟机安装和使用教程(附最新安装包+以ubuntu为例子讲解)
目录 一、VMware Workstation 17 Pro 简介 二、新功能与改进 三、安装教程 3.1、下载安装包 3.2、运行安装包 四、创建虚拟机 五、启动虚拟机 六、总结与展望 一、VMware Workstation 17 Pro 简介 VMware Workstation 17 Pro是VMware公司为专业用户打造的一款虚拟化软件…...
c语言 / 指针错误的几种情况
1.未初始化的指针,直接释放 int *p; //计算机随机指向一片内存 2.free一个指针,指针没有指向NULL,直接使用 int *p(int *)malloc(sizeof(int)); free(p); //p依旧指向释放前内存的地址, 但是这片内存已经被释放, 被其他变量重新使用, 正…...
Stable-Diffusion——Windows部署教程
Windows 参考文章:从零开始,手把手教你本地部署Stable Diffusion Webui AI绘画(非最新版) 一键脚本安装 默认环境安装在项目路径的venv下 conda create -n df_env python3.10安装pytorch:(正常用国内网就行) python -…...
Day60.算法训练
912. 排序数组 归并排序 class Solution {public int[] sortArray(int[] nums) {int lo 0;int hi nums.length - 1;int[] assist new int[nums.length];sortArray(nums, assist, lo, hi);return nums;}private void sortArray(int[] nums, int[] assist, int lo, int hi) …...
深入了解Java8新特性-日期时间API之TemporalQuery、TemporalQueries
阅读建议 嗨,伙计!刷到这篇文章咱们就是有缘人,在阅读这篇文章前我有一些建议: 本篇文章大概2000多字,预计阅读时间长需要5分钟。本篇文章的实战性、理论性较强,是一篇质量分数较高的技术干货文章&#x…...
记录一次现网问题排查(分享查域名是否封禁小程序)
背景: 收到工单反馈说现网业务一个功能有异常,具体现象是tc.hb.cn域名无法访问,客户地区是河南省,这里记录下排查过程和思路。 首先梳理链路 客户端域名 tc.hb.cn cname—> domainparking-dnspod.cn(新加坡clb)—> snat—&…...
linux下实现Qt程序实现开机自启动
1.原理 要想实现开机自启动,首先,QT是没有这种实现的,最好是靠电脑开机的启动目录启动软件,下面这个目录 /etc/xdg/autostart 这是操作系统中用于配置启动项的目录,该目录下存放着开机自启动的启动器(.desktop)文件…...
12年不上班,我靠什么支撑到现在
我已经12年没去上过班了,14年从学校辞职出来后,就没再给人打过工。虽然我不上班,但身边人都觉得我很会赚钱,觉得我很幸运,也觉得我很有勇气。 其实,并不是我多勇敢,是因为早在2014年,…...
告别联网烦恼:uv离线安装科学计算包的3种实战姿势(NumPy/TensorFlow实测)
数据科学家必备:三种高效离线安装Python科学计算包的终极方案 实验室的服务器突然断网了,而你的TensorFlow模型训练正进行到关键时刻——这种场景对数据科学家来说简直是噩梦。别担心,离线安装Python包并非无解难题。本文将带你掌握三种经过实…...
手把手教你用华为昇腾A2-910b显卡,一键部署中文Embedding和Rerank模型
华为昇腾A2-910b实战:中文Embedding与Rerank模型高效部署指南 当你在深夜的办公室里盯着昇腾显卡的报错日志时,可能正经历着每个AI工程师都熟悉的"部署地狱"。别担心,这份指南将带你绕过所有坑点,用最直接的方式在华为A…...
突破窗口尺寸限制:WindowResizer如何重新定义Windows界面控制
突破窗口尺寸限制:WindowResizer如何重新定义Windows界面控制 【免费下载链接】WindowResizer 一个可以强制调整应用程序窗口大小的工具 项目地址: https://gitcode.com/gh_mirrors/wi/WindowResizer WindowResizer是一款专注于解决Windows窗口尺寸调整难题的…...
基于Simulink的无刷电机调速系统仿真
目 录 第一章 绪论 1 1.1 研究背景及研究意义 1 1.2 无刷直流电机调速系统的国内外研究现状 2 1.3 本文的主要研究内容及章节安排 3 第二章 无刷直流电机的基本原理 4 2.1 无刷直流电机的基本结构 4 2.1.1 电机本体 4 1.电动机定子 4 2. 电动机转子 5 2.1.2 位置传感器 5 2.…...
告别快捷键混乱:Hotkey Detective让你的Windows操作回归掌控
告别快捷键混乱:Hotkey Detective让你的Windows操作回归掌控 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 在…...
深入理解MUNIT架构:内容编码器与风格编码器的完美结合
深入理解MUNIT架构:内容编码器与风格编码器的完美结合 【免费下载链接】MUNIT Multimodal Unsupervised Image-to-Image Translation 项目地址: https://gitcode.com/gh_mirrors/mu/MUNIT MUNIT(Multimodal Unsupervised Image-to-Image Translat…...
Wan2.2-I2V-A14B协作开发:利用GitHub进行模型配置与提示词库管理
Wan2.2-I2V-A14B协作开发:利用GitHub进行模型配置与提示词库管理 1. 团队协作的痛点与解决方案 在AI模型开发过程中,团队协作常常面临配置混乱、经验难以共享、问题追踪困难等挑战。特别是对于Wan2.2-I2V-A14B这样的复杂模型,不同环境下的部…...
GitHub加速革命:告别龟速下载,提升开发效率的终极方案
GitHub加速革命:告别龟速下载,提升开发效率的终极方案 【免费下载链接】Fast-GitHub 国内Github下载很慢,用上了这个插件后,下载速度嗖嗖嗖的~! 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 在深…...
PyTorch 2.8动态计算图深度解析:自定义算子与性能优化技巧
PyTorch 2.8动态计算图深度解析:自定义算子与性能优化技巧 1. 动态计算图的核心魅力 PyTorch的动态计算图一直是其区别于其他深度学习框架的标志性特性。在2.8版本中,这个机制变得更加灵活高效。简单来说,动态计算图就像一张可以随时修改的…...
