首頁  >  文章  >  web前端  >  JavaScript ES6中const、let與var的對比詳解

JavaScript ES6中const、let與var的對比詳解

陈政宽~
陈政宽~原創
2017-06-28 14:25:341582瀏覽

這篇文章主要為大家介紹了在JavaScript中const、let與var對比的相關資料,文中透過範例程式碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起看看吧。

ECMAScript 6 新增 const 和 let 指令,用來宣告變數。


聲明方式 #變數提升 作用域 初始值 重複定義
const #區塊級 需要 不允許
let 「區塊層級
#var

函數層級


不需要

允許





變數提升:

const 和let 必須先宣告再使用,不支援變數提升

console.log(c1, l1, v1);
// 报错
// Uncaught ReferenceError: c1 is not defined
 
const c1 = 'c1';
let l1 = 'l1';
var v1 = 'v1';


作用域:
const,let 支援區塊層級作用域,有效避免變數覆寫

#

const c21 = 'c21';
let l21 = 'l21';
var v21 = 'v21';
 
if (0.1 + 0.2 != 0.3) {
 const c21 = 'c22';
 let l21 = 'l22';
 var v21 = 'v22';
 
 console.log(c21, l21, v21);
 // 输出 c22 l22 v22
}
 
console.log(c21, l21, v21);
// 输出 c21 l21 v22

##區塊層級作用域,在外層不能直接存取內層變數

if (0.1 + 0.2 != 0.3) {
 const c22 = 'c22';
 let l22 = 'l22';
 var v22 = 'v22';
 
 console.log(c22, l22, v22);
 // 输出 c22 l22 v22
}
 
console.log(c22, l22, v22);
// 报错
// Uncaught ReferenceError: c22 is not defined
// 同样地, l22 is not defined


#const 定義
常數

,該常數不能賦值,但該常數的

屬性
可以賦值

const c231 = {};
const c232 = [];
 
c231.name = 'seven';
c232.push(27);
 
console.log(c231, c232);
// 输出 {name: "seven"} [27]
 
// 禁止给对象赋值,应该使用 Object.freeze
 
const c233 = Object.freeze({});
const c234 = Object.freeze([]);
 
c233.name = 'seven';
// 普通模式下不报错
// 严格模式下报错
// Uncaught TypeError: Cannot add property name, object is not extensible
  
c234.push(27);
// 普通模式下就会报错
// Uncaught TypeError: Cannot add property 0, object is not extensible
 
console.log(c233, c234);
// 输出 {} []


全域變數不再設定為頂層物件(window)的屬性,有效避免全域變數污染


const c24 = 'c24';
let l24 = 'l24';
 
console.log(c24, l24);
// 输出 c24 l24
 
console.log(window.c24, window.l24);
// 输出 undefined undefined

#符合預期的for 迴圈


for (var i = 0; i != 3; i++) {
 setTimeout(function() {
  console.log(i);
 },10);
}
// 依次打印

for (let i = 0; i != 3; i++) {
 setTimeout(function() {
  console.log(i);
 },10);
}
// 依次打印,为啥呢

可以看到在for 迴圈中使用let 方式宣告變數才是符合預期。

在 for 中每一次循環,let 都是重新宣告變量,並且因為 JavaScript 引擎會記住上一次循環的值,初始化 i 時在上一輪的基礎上計算。 可以看到在 for 迴圈中至少有兩層作用域,看下面的範例比較容易理解。

######
for (let i = 0; i != 3; i++) {
 let i = 'seven';
 console.log(i);
}
console.log('eight');
// 依次打印
seven
seven
seven
eight
###############初始值:###const 宣告的變數必須設定初始值,且不能重複賦值。 ############
const c3 = 'c3';
let l3 = 'l3';
var v3 = 'v3';
 
console.log(c3, l3, v3);
// 输出 c3 l3 v3
 
c3 = 2; // Uncaught TypeError: Assignment to constant variable
l3 = 2;
v3 = 2;
 
console.log(c3, l3, v3);
// 输出 c3 2 2
 
const c32;
// 报错
// Uncaught SyntaxError: Missing initializer in const declaration
############重複定義:const 和let 不支援重複定義######const、let 縮小了變數作用域,完美避免變數污染;const 固定變數(即固定變數類型),對於弱型別JavaScript 來說,可以明顯提升效能。建議在應用程式中使用 const、let 宣告變數。 ############總結##########

以上是JavaScript ES6中const、let與var的對比詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn