轻松上手,快乐学习!

JS 教程

JS 首页JS 教程JS 简介JS 如何使用JS 输出JS 语句JS 语法JS 注释JS 变量JS 运算符JS 算法JS 赋值JS 数据类型JS 函数JS 对象JS 事件JS 字符串JS 字符串方法JS 数值JS 数值方法JS 数组JS 数组方法JS 数组排序JS 数组迭代JS 日期JS 日期格式JS 日期获取方法JS 日期设置方法JS 数学运算JS 随机数JS 布尔运算符JS 比较运算符JS 条件语句JS Switch 语句JS For 循环JS While 循环JS BreakJS 类型转换JS 位运算符JS 正则表达式JS 错误处理JS 作用域JS HoistingJS 严格模式JS this 关键词JS Let 关键词JS Const 关键词JS 箭头函数JS 类JS 调试JS 样式指南JS 最佳实践JS 常见错误JS 性能优化JS 保留关键词JS 版本JS ES5JS ES6JS JSONJS FormsForms APIObject 对象定义Object 对象属性Object 对象方法Object DisplayObject 对象访问器Object 对象构造器Object 对象原型Object ECMAScript 5JS 函数定义JS 函数参数JS 函数调用JS Call 函数JS Apply 函数JS 函数闭包Class 类简介Class 类继承Class StaticJS 回调JS 异步JS PromisesJS Async/AwaitDOM 简介DOM 方法DOM 文档DOM 元素DOM HTMLDOM CSSDOM 动画DOM 事件DOM 事件监听DOM 导航DOM 节点DOM 集合DOM 节点列表JS WindowJS ScreenJS LocationJS HistoryJS NavigatorJS 弹出框JS TimingJS CookiesAJAX 简介AJAX XMLHttpAJAX 请求AJAX 响应AJAX XML 文件AJAX PHPAJAX ASPAJAX 数据库AJAX 应用程序AJAX 实例JSON 简介JSON 语法JSON vs XMLJSON 数据类型JSON 解析JSON 字符串化JSON 对象JSON 数组JSON PHPJSON HTMLJSON JSONPWeb API 简介Web History APIWeb Storage APIWeb Geolocation APIjQuery 选择器jQuery HTMLjQuery CSSjQuery DOMJS 实例JS HTML DOMJS HTML 输入JS HTML 对象JS HTML 事件JS BrowserJS 编辑器JS 练习JS 测验

JS 参考手册

JS 参考手册(类别排序)JS 参考手册(字母排序)


JavaScript Const


ECMAScript 2015

ES2015 引入了两个重要的 JavaScript 新关键词:letconst

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

实例

const PI = 3.141592653589793;
PI = 3.14;      // 这将给出一个错误
PI = PI + 10;   // 这也会报错
亲自试一试 »

块作用域

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

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

实例

var x = 10;
// 这里 x 是 10
{
  const x = 2;
  // 这里 x 是 2
}
// 这里 x 是 10
亲自试一试 »

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


在声明时赋值

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

Incorrect

const PI;
PI = 3.14159265359;

Correct

const PI = 3.14159265359;

不是真正的常数

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

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

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


原始值

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

实例

const PI = 3.141592653589793;
PI = 3.14;      // 这会报错
PI = PI + 10;   // 这也会报错
亲自试一试 »

常量对象可以更改

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

实例

// 你可以创建一个 const 对象:
const car = {type:"Fiat", model:"500", color:"white"};

// 你可以改变一个属性:
car.color = "red";

// 你可以添加一个属性:
car.owner = "Johnson";
亲自试一试 »

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

实例

const car = {type:"Fiat", model:"500", color:"white"};
car = {type:"Volvo", model:"EX60", color:"red"};    // ERROR
亲自试一试 »

常量数组可以更改

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

实例

// 您可以创建一个常量数组:
const cars = ["Saab", "Volvo", "BMW"];

// 你可以改变一个元素:
cars[0] = "Toyota";

// 您可以添加一个元素:
cars.push("Audi");
亲自试一试 »

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

实例

const cars = ["Saab", "Volvo", "BMW"];
cars = ["Toyota", "Volvo", "Audi"];    // ERROR
亲自试一试 »

浏览器支持

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

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

Chrome 49 IE / Edge 11 Firefox 36 Safari 10 Opera 36
Mar, 2016 Oct, 2013 Feb, 2015 Sep, 2016 Mar, 2016

重新声明

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

实例

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

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

实例

var x = 2;         // 允许
const x = 2;       // 不允许
{
  let x = 2;     // 允许
 const x = 2;   // 不允许
}

在同一作用域或块中,为已有的 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;   // 允许
}

提升

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

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

实例

This is OK:

carName = "Volvo";
alert(carName);
var carName;
亲自试一试 »

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

意思:代码块知道变量,但在声明之前不能使用它。

在声明 const 变量之前就使用它会导致 ReferenceError.

变量从块的开头一直处于"暂时死区",直到声明为止:

实例

这将导致语法错误(SyntaxError):

carName = "Volvo";
alert(carname);
const carName;
亲自试一试 »