es6 基础学习之var let 和 const 命令 区别和相关

在 ES6(ECMAScript 2015)中,varletconst 是用于声明变量的三种方式,它们有几个关键的区别。

1. 作用域

  • var: 声明的变量会被提升到其函数或全局作用域的顶部。
  • letconst: 声明的变量仅在其块级作用域(block scope)内有效。

示例:

javascript 复制代码
function demoVar() {
  if (true) {
    var x = 1; // x 可以在整个函数作用域内访问
  }
  console.log(x); // 输出 1
}

function demoLet() {
  if (true) {
    let y = 1; // y 仅在这个块级作用域内有效
  }
  console.log(y); // ReferenceError: y is not defined
}

2. 重复声明

  • var: 允许重复声明同一个变量。
  • letconst: 不允许在同一个作用域内重复声明同一个变量。

示例:

javascript 复制代码
var x = 1;
var x = 2; // 有效

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

const z = 1;
const z = 2; // SyntaxError: Identifier 'z' has already been declared

3. 可变性

  • varlet: 声明的变量可以重新赋值。
  • const: 声明的变量不能重新赋值,但如果它是一个对象或数组,其内部状态是可以被改变的。

示例:

javascript 复制代码
var x = 1;
x = 2; // 有效

let y = 1;
y = 2; // 有效

const z = 1;
z = 2; // TypeError: Assignment to constant variable.

const obj = { prop: 1 };
obj.prop = 2; // 有效

4. 提升(Hoisting)

  • var: 变量会被提升,但只有声明会被提升,初始化(如果有)则不会。
  • letconst: 声明不会被提升,访问变量前必须声明。

示例:

javascript 复制代码
console.log(a); // 输出 undefined
var a = 1;

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

console.log(c); // ReferenceError: Cannot access 'c' before initialization
const c = 1;

这些是 varletconst 的主要区别。在现代 JavaScript 开发中,通常推荐使用 letconst,因为它们提供了块级作用域和不可变性,这有助于编写更清晰、更易维护的代码。

相关推荐
假如让我当三天老蒯13 小时前
Options API(选项式 API) 和 Composition API(组合式 API)
前端·vue.js·面试
秃头网友小李3 天前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
徐小夕4 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
奋斗吧程序媛4 天前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药4 天前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc
jay神4 天前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
一杯奶茶¥4 天前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
英勇无比的消炎药4 天前
一站式搞定品牌风格:TinyRobot 主题定制从入门到精通
vue.js
尽欢i4 天前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js
因_崔斯汀4 天前
Vue 模板编译:HTML 是怎么变成 JS 的?
前端·vue.js