【JS】var与let的区别

1. 作用域(Scope)

  • var:函数作用域(function-scoped)
  • let:块级作用域(block-scoped)
javascript 复制代码
// var 例子
function varExample() {
  if (true) {
    var x = 10; // 在整个函数内都可用
  }
  console.log(x); // 10 - 可以访问
}

// let 例子
function letExample() {
  if (true) {
    let y = 20; // 只在块内可用
  }
  console.log(y); // ReferenceError: y is not defined
}

2. 重复声明

  • var:允许重复声明
  • let:不允许重复声明
javascript 复制代码
var a = 1;
var a = 2; // ✅ 允许

let b = 1;
let b = 2; // ❌ SyntaxError: Identifier 'b' has already been declared

3. 变量提升(Hoisting)

  • var :会变量提升,但初始化为 undefined
  • let:也会提升,但存在"暂时性死区"
javascript 复制代码
console.log(c); // undefined
var c = 5;

console.log(d); // ReferenceError: Cannot access 'd' before initialization
let d = 5;

4. 全局对象属性

  • var 在全局作用域声明时,会成为全局对象的属性
  • let 在全局作用域声明时,不会成为全局对象的属性
javascript 复制代码
var globalVar = "hello";
let globalLet = "world";

console.log(window.globalVar); // "hello"(在浏览器中)
console.log(window.globalLet); // undefined

5. 循环中的表现差异

javascript 复制代码
// var 在循环中的问题
for (var i = 0; i < 3; i++) {
  setTimeout(() => {
    console.log(i); // 输出 3 3 3
  }, 100);
}

// let 解决这个问题
for (let j = 0; j < 3; j++) {
  setTimeout(() => {
    console.log(j); // 输出 0 1 2
  }, 100);
}

最佳实践建议

  1. 优先使用 let ,避免 var 带来的意外行为
  2. 只在需要变量提升特性时才使用 var(现在基本不需要)
  3. 使用 const 声明不应重新赋值的变量
  4. 保持代码的块级作用域清晰

现代JavaScript开发中,基本已经完全用 letconst 替代 var

相关推荐
lbh1 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
小王不爱笑1321 小时前
IO 模型
开发语言·python
知我Deja_Vu2 小时前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
AI+程序员在路上2 小时前
CANopen 协议:介绍、调试命令与应用
linux·c语言·开发语言·网络
2401_831824962 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct2 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
qq_406176142 小时前
深入浅出 Pinia:Vue3 时代的状态管理新选择
javascript·vue.js·ecmascript
m0_518019483 小时前
C++与机器学习框架
开发语言·c++·算法
wefly20173 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
ZTLJQ3 小时前
深入理解逻辑回归:从数学原理到实战应用
开发语言·python·机器学习