JavaScript Const

ECMAScript 2015

ES2015 引入了两个重要的 JavaScript 新关键词:let 和 const。

通过 const 定义的变量与 let 变量类似,但不能重新赋值:

实例

  1. const PI = 3.141592653589793;
  2. PI = 3.14; // 会出错
  3. PI = PI + 10; // 也会出错

块作用域

块作用域内使用 const 声明的变量与 let 变量相似。

在本例中,x 在块中声明,不同于在块之外声明的 x:

实例

  1. var x = 10;
  2. // 此处,x 为 10
  3. {
  4. const x = 6;
  5. // 此处,x 为 6
  6. }
  7. // 此处,x 为 10

您可以在上一章 JavaScript Let 中学到更多有关块作用域的知识。

在声明时赋值

JavaScript const 变量必须在声明时赋值:

不正确

  1. const PI;
  2. PI = 3.14159265359;

正确

  1. const PI = 3.14159265359;

不是真正的常数

关键字 const 有一定的误导性。

它没有定义常量值。它定义了对值的常量引用。

因此,我们不能更改常量原始值,但我们可以更改常量对象的属性。

原始值

如果我们将一个原始值赋给常量,我们就不能改变原始值:

实例

  1. const PI = 3.141592653589793;
  2. PI = 3.14; // 会出错
  3. PI = PI + 10; // 也会出错

常量对象可以更改

您可以更改常量对象的属性:

实例

  1. // 您可以创建 const 对象:
  2. const car = {type:"porsche", model:"911", color:"Black"};
  3.  
  4. // 您可以更改属性:
  5. car.color = "White";
  6.  
  7. // 您可以添加属性:
  8. car.owner = "Bill";

但是您无法重新为常量对象赋值:

实例

  1. const car = {type:"porsche", model:"911", color:"Black"};
  2. car = {type:"Volvo", model:"XC60", color:"White"}; // ERROR

常量数组可以更改

您可以更改常量数组的元素:

实例

  1. // 您可以创建常量数组:
  2. const cars = ["Audi", "BMW", "porsche"];
  3.  
  4. // 您可以更改元素:
  5. cars[0] = "Honda";
  6.  
  7. // 您可以添加元素:
  8. cars.push("Volvo");

但是您无法重新为常量数组赋值:

实例

  1. const cars = ["Audi", "BMW", "porsche"];
  2. cars = ["Honda", "Toyota", "Volvo"]; // ERROR

浏览器支持

Internet Explorer 10 或更早版本不支持 const 关键词。

下表定义了第一个完全支持 const 关键词的浏览器版本:

Chrome 49 IE / Edge 11 Firefox 36 Safari 10 Opera 36
2016 年 3 月 2013 年 10 月 2015 年 2 月 2016 年 9 月 2016 年 3 月

重新声明

在程序中的任何位置都允许重新声明 JavaScript var 变量:

实例

  1. var x = 2; // 允许
  2. var x = 3; // 允许
  3. x = 4; // 允许

在同一作用域或块中,不允许将已有的 var 或 let 变量重新声明或重新赋值给 const:

实例

  1. var x = 2; // 允许
  2. const x = 2; // 不允许
  3. {
  4. let x = 2; // 允许
  5. const x = 2; // 不允许
  6. }

在同一作用域或块中,为已有的 const 变量重新声明声明或赋值是不允许的:

实例

  1. const x = 2; // 允许
  2. const x = 3; // 不允许
  3. x = 3; // 不允许
  4. var x = 3; // 不允许
  5. let x = 3; // 不允许
  6.  
  7. {
  8. const x = 2; // 允许
  9. const x = 3; // 不允许
  10. x = 3; // 不允许
  11. var x = 3; // 不允许
  12. let x = 3; // 不允许
  13. }

在另外的作用域或块中重新声明 const 是允许的:

实例

  1. const x = 2; // 允许
  2.  
  3. {
  4. const x = 3; // 允许
  5. }
  6.  
  7. {
  8. const x = 4; // 允许
  9. }

提升

通过 var 定义的变量会被提升到顶端。如果您不了解什么是提升(Hoisting),请学习提升这一章。

您可以在声明 var 变量之前就使用它:

实例

  1. carName = "Volvo"; // 您可以在此处使用 carName
  2. var carName;

通过 const 定义的变量不会被提升到顶端。

const 变量不能在声明之前使用:

实例

  1. carName = "Volvo"; // 您不可以在此处使用 carName
  2. const carName = "Volvo";