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

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.

主站蜘蛛池模板: 临沭县| 阳朔县| 瓦房店市| 霍州市| 嘉义市| 宜城市| 台安县| 林州市| 彩票| 太原市| 姚安县| 来宾市| 南汇区| 廉江市| 广宁县| 莒南县| 陆河县| 宾川县| 荆门市| 平江县| 安新县| 永平县| 河源市| 长寿区| 靖江市| 延长县| 大荔县| 郸城县| 龙里县| 兴安盟| 子长县| 梧州市| 婺源县| 应城市| 偃师市| 江城| 祁阳县| 奎屯市| 南投县| 洞头县| 农安县|