JavaScript变量声明:var的奥秘

在 JavaScript 中,var 是最传统的变量声明关键字。使用 var 声明的变量有几个特点:

  1. 函数作用域var 声明的变量具有函数作用域,这意味着变量只能在声明它的函数内部访问。如果在函数外部声明,则为全局作用域。

  2. 变量提升var 声明的变量会发生变量提升(hoisting),这意味着变量的声明会被提升到当前作用域的顶部,但是初始化不会被提升。因此,你可以在声明之前使用变量,但它会被初始化为 undefined

  3. 重复声明 :使用 var 可以在同一作用域内重复声明同一个变量,后面的声明会覆盖前面的声明。

  4. 不限制声明次数 :你可以多次使用 var 关键字声明同一个变量,每次声明都会创建一个新的变量。

下面是一个使用 var 声明变量的例子:

javascript 复制代码
function myFunction() {
  var x = 10;
  if (true) {
    var x = 20; // 重复声明,覆盖外层的 x
    console.log(x); // 输出 20
  }
  console.log(x); // 输出 20,内层的声明覆盖了外层的声明
}

myFunction();

在上面的例子中,尽管 x 被声明了两次,但由于变量提升,实际上在函数内部只有一个 x 变量,其值在条件语句中被重新赋值为 20

随着 ES6 的引入,推荐使用 letconst 来声明变量,因为它们提供了块作用域和更严格的限制,有助于避免变量提升和重复声明等问题。

相关推荐
橙子家9 分钟前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
To_OC1 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
最新资讯动态1 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态1 小时前
游戏出海,从产品走向体系
前端
最新资讯动态1 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态1 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝3 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen3 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒4 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
山河木马5 小时前
矩阵专题0-webGL中的矩阵
javascript·webgl·计算机图形学