当前位置: 首页 > news >正文

在JavaScript中,let 和 const有什么不同

在JavaScript中,let 和 const 是用于声明变量的关键字,但它们有一些重要的区别

1.重新赋值

  • let 声明的变量可以重新赋值。
  • const 声明的变量必须在声明时初始化,并且之后不能重新赋值

let a = 10;
a = 20; // 有效,a 的值变为 20const b = 30;
b = 40; // 错误,TypeError: Assignment to constant variable.

2.块级作用域

  • let 和 const 都具有块级作用域,这意味着它们只在声明它们的块(由 {} 包围的代码块)内有效。
  • 相比之下,var 声明的变量具有函数作用域或全局作用域(如果声明在函数外部),这可能会导致一些意外的行为。
if (true) {let x = 5;const y = 10;var z = 15;
}console.log(x); // 错误,x is not defined
console.log(y); // 错误,y is not defined
console.log(z); // 输出 15,因为 var 声明的变量具有函数作用域(或全局作用域)

3.暂时性死区(Temporal Dead Zone, TDZ)

  • 在块级作用域内,let 和 const 声明的变量在声明之前存在一个“暂时性死区”,在这个区域内访问这些变量会抛出 ReferenceError
  • var 声明的变量没有暂时性死区的问题。
console.log(foo); // 输出 undefined,因为 var 声明的变量会被提升到作用域的顶部,但值为 undefined
var foo = 'Hello';console.log(bar); // 错误,ReferenceError: Cannot access 'bar' before initialization
let bar = 'World';console.log(baz); // 错误,ReferenceError: Cannot access 'baz' before initialization
const baz = 'JavaScript';

常量性

  • 虽然 const 声明的是“常量”,但这并不意味着它的值不能改变。实际上,const 确保的是变量绑定的引用不能改变。如果 const 绑定的是一个对象或数组,那么对象或数组的内容仍然可以修改。
const obj = { name: 'Alice' };
obj.name = 'Bob'; // 有效,obj 的内容改变了
console.log(obj.name); // 输出 'Bob'const arr = [1, 2, 3];
arr.push(4); // 有效,arr 的内容改变了
console.log(arr); // 输出 [1, 2, 3, 4]const arr2 = [1, 2, 3];
arr2 = [4, 5, 6]; // 错误,TypeError: Assignment to constant variable.

http://www.lryc.cn/news/510461.html

相关文章:

  • Mysq学习-Mysql查询(4)
  • 安装torch-geometric库
  • Java数组深入解析:定义、操作、常见问题与高频练习
  • Docker-构建自己的Web-Linux系统-镜像webtop:ubuntu-kde
  • 【C语言练习(17)—输出杨辉三角形】
  • SpringMVC学习(二)——RESTful API、拦截器、异常处理、数据类型转换
  • React 第二十节 useRef 用途使用技巧注意事项详解
  • VIVO Java开发面试题及参考答案
  • C# Winfrom chart图 实例练习
  • iOS从Matter的设备认证证书中获取VID和PID
  • 带着国标充电器出国怎么办? 适配器模式(Adapter Pattern)
  • 破解海外业务困局:新加坡服务器托管与跨境组网策略
  • Mybatis-Plus快速入门
  • Chrome被360导航篡改了怎么改回来?
  • Coding(Jenkinsfile)+ Docker 自动化部署 Springboot —— 图文细节和一些注意事项说明
  • docker django uwsgi 报错记录
  • 数据分析思维(五):分析方法——假设检验分析方法
  • 【ES6复习笔记】集合Set(13)
  • 基础爬虫案例实战
  • 深度学习工作:从追求 SoTA 到揭示新现象
  • 学习记录—正则表达式-基本语法
  • 智慧农业物联网传感器:开启农业新时代
  • 普通人怎么入门学习并使用AI?
  • Java中处理if-else的几种高级方法
  • 前端知识补充—CSS
  • 企业架构学习笔记-数字化转型
  • Linux网络——TCP的运用
  • Vue3之状态管理Vuex
  • DPO(Direct Preference Optimization)算法解释:中英双语
  • Hostapd2.11解析笔记