首页 > Web开发 > 详细

js变量作用域

时间:2019-05-07 20:57:24      阅读:139      评论:0      收藏:0      [点我收藏+]

1,变量作用域

(1)局部变量:在函数中通过var声明的变量。

  全局变量:在函数外通过var声明的变量。

  没有声明就使用的变量,默认为全局变量,不论这个变量在哪被使用。

(2)var 可以先使用再定义。如下

  x = 5; // 变量 x 设置为 5

  elem = document.getElementById("demo"); // 查找元素 
  elem.innerHTML = x;                     // 在元素中显示 x

  var x; // 声明 x

  (3)  let和const

  let 声明的变量只在 let 命令所在的代码块内有效。

  const 声明一个只读的常量,一旦声明,常量的值就不能改变。

  

  使用 var 关键字声明的变量在任何地方都可以修改:

  var x = 2; // 合法
  var x = 3; // 合法
  x = 4; // 合法

  在相同的作用域或块级作用域中,不能使用 const 关键字来重置 var 和 let关键字声明的变量:

  var x = 2;         // 合法
  const x = 2;       // 不合法
  {
      let x = 2;     // 合法
      const x = 2;   // 不合法
  }

  在相同的作用域或块级作用域中,不能使用 const 关键字来重置 const 关键字声明的变量:

  const x = 2;       // 合法
  const x = 3;       // 不合法
  x = 3;             // 不合法
  var x = 3;         // 不合法
  let x = 3;         // 不合法

  {
      const x = 2;   // 合法
      const x = 3;   // 不合法
      x = 3;         // 不合法
      var x = 3;     // 不合法
      let x = 3;     // 不合法
  }

  const 关键字在不同作用域,或不同块级作用域中是可以重新声明赋值的:

  const x = 2;       // 合法

  {
      const x = 3;   // 合法
  }
  
  {
      const x = 4;   // 合法
  }

 

js变量作用域

原文:https://www.cnblogs.com/xutiantian/p/10827835.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!