官术网_书友最值得收藏!

Let and const

In ES5 JavaScript, we use the var keyword to define variables. In most cases, var can simply be replaced with let, with the major difference between the two constructs being the scoping of the variable with respect to blocks. The following example from MDN web docs, or previously Mozilla Developer Network (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let), demonstrates the subtle difference between the two:

function varTest() {
var x = 1;
if (true) {
var x = 2; // same variable!
console.log(x); // 2
}
console.log(x); // 2
}

function letTest() {
let x = 1;
if (true) {
let x = 2; // different variable
console.log(x); // 2
}
console.log(x); // 1
}

So, while you must use additional caution in cases like the preceding one, in most cases you can simply replace var with let.

The const keyword, unlike let, defines a variable as a constant; that is, you cannot reassign a variable initialized with const at a later date. For example, the following code causes an error with a message similar to invalid assignment to const a:

const a = 1;
a = 2;

On the other hand the same code, using var or let to define a, would run successfully.

Note that if a is an object, you are allowed to modify object properties of a.

The following code will run successfully:

const obj = {};
obj.name = ‘My Object’;

However, attempting to redefine objects such as in obj = {name: “other object”} would cause an error.

I find that in most programming contexts, const is typically more appropriate than let, as most variables you use never need to be redefined. My recommendation is to use const as much as you can, and use let only when you have a reason to redefine the variable later.

主站蜘蛛池模板: 山东省| 清原| 农安县| 巫溪县| 新丰县| 文成县| 清水河县| 澜沧| 安西县| 濮阳市| 中超| 鄢陵县| 客服| 富宁县| 五莲县| 沙湾县| 建水县| 平度市| 麦盖提县| 莱西市| 元朗区| 内乡县| 聂荣县| 古交市| 宣城市| 昭平县| 综艺| 滨州市| 马山县| 兴义市| 醴陵市| 陕西省| 疏勒县| 闽侯县| 大余县| 鄱阳县| 嘉鱼县| 禹城市| 洪江市| 罗田县| 宜丰县|