摘要:但是如果使用,作用域塊級作用域內,在還沒使用聲明一個變量的時候,訪問該變量,將會獲得,從作用域開始到語句之間,就是暫存死區(qū)。
0x001 var
語法
var varname1 [= value1 [, varname2 [, varname3 ... [, varnameN]]]];
使用
var a, b=2 // 聲明多個變量,可以賦值,也可以不賦值 a=1 // 先聲明,再賦值
var變量提升
使用var聲明的變量將會被提升到函數的頂部
console.log(a) // undefined var a =2 console.log(a) // 2 console.log(b) //Uncaught ReferenceError: b is not defined...
以上代碼相當于
var a console.log(a) // undefined a=2 console.log(a) // 2 console.log(b) //Uncaught ReferenceError: b is not defined...0x002 let
語法
let var1 [= value1] [, var2 [= value2]] [, ..., varN [= valueN]];
使用
let a, b = 2 // 聲明多個變量,賦值不賦值無所謂 a = 2 // 聲明之后再賦值
不再提升
console.log(a) // Uncaught ReferenceError: a is not defined... let a=1
注意:猜測, 使用babel翻譯一下代碼發(fā)現,只是let變成了var,所以使用babel轉義之后的代碼依舊會提升
不能重復聲明
let a=1 let a=2 // Uncaught SyntaxError: Identifier "a" has already been declared0x003 const
語言
const name1 = value1 [, name2 = value2 [, ... [, nameN = valueN]]];
使用
const a=1, b=2 // 不能省略的值
不能省略的值
const c // Uncaught SyntaxError: Missing initializer in const declaration
不能重復賦值
const d=4 d=5 // Uncaught TypeError: Assignment to constant variable.
可以修改的引用
const e=[] e[0]=0 console.log(e) //[0]0x004 塊級作用域
塊級作用域是隨著let、const而來最有用的特性了,在之前的js中,js的作用域是函數級的,由此帶來的幾個臭名昭著的問題:
意外被修改的值
function varTest() { var x = 1; if (true) { var x = 2; // 同樣的變量! console.log(x); // 2 } console.log(x); // 2 }
可以使用let避免了
function letTest() { let x = 1; if (true) { let x = 2; // 不同的變量 console.log(x); // 2 } console.log(x); // 1 }
萬惡的for循環(huán)和點擊事件
var list = document.getElementById("list"); for (var i = 0; i < 5; i++) { var item = document.createElement("LI"); item.appendChild(document.createTextNode("Item " + i)); item.onclick = function (ev) { console.log("Item " +i + " is clicked."); }; list.appendChild(item); } console.log(i) // 5
如果點擊上面,不管點擊哪個,顯示出來的都是Item 5 is clicked.,雖然可以使用閉包解決,但是現在有了更好的方案
let list = document.getElementById("list"); for (let i = 0; i < 5; i++) { let item = document.createElement("LI"); item.appendChild(document.createTextNode("Item " + i)); item.onclick = function (ev) { console.log("Item " +i + " is clicked."); }; list.appendChild(item); }0x005 作用域規(guī)則很簡單
{}塊內形成一個作用域,包括if、else、while、class、do...while、{}、function
{ const f=6 } console.log(f) // Uncaught ReferenceError: f is not defined
for循環(huán)中用let聲明一個初始因子,該因子在每個循環(huán)內都是一個新的作用域
for (let i = 0; i < 10; i++) { console.log(i); } console.log(i) // Uncaught ReferenceError: i is not defined
switch只有一個作用域
switch (x) { case 0: let foo; break; case 1: let foo; break; } // Uncaught SyntaxError: Identifier "foo" has already been declared0x006 暫存死區(qū)-Temporal Dead Zone-TDZ
隨著let和const的引入,也引入了暫存死區(qū)的概念。使用var的時候,作用域內(函數作用域),在還沒使用var聲明一個變量的時候,訪問該變量,將會獲得undefined。但是如果使用let,作用域(塊級作用域)內,在還沒使用let聲明一個變量的時候,訪問該變量,將會獲得ReferenceError,從作用域開始到let語句之間,就是暫存死區(qū)。
{ console.log(a) // Uncaught ReferenceError: a is not defined console.log(b) // Uncaught ReferenceError: b is not defined console.log(c) // undefined // 暫存死區(qū) let a =1 const b=2 var c=3 }
注意:猜測, 使用babel翻譯一下代碼發(fā)現,只是let變成了var,所以使用babel轉義之后可能不存在暫存死區(qū)
0x007 總結盡量使用let和const,如果希望改變該變量的值,則使用let,如果希望不再改變該變量的值或者引用,則使用const,讓var成為歷史。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/99070.html
摘要:全局作用域在最頂層聲明的變量成為全局變量,全局變量擁有全局作用域,它們在程序的任何地方都是能夠被訪問到。作用域的主要作用是能夠控制變量是使用范圍。程序將會被中斷,這個特性被稱為暫存死區(qū)。 1. 變量聲明、初始化 Javascript中使用一個變量之前需要先聲明,我們可以使用var、let、const來聲明一個變量。如果在給聲明的變量指定初始值,就是初始化。如: var a = 1; ...
摘要:凍結對象可以使用方法。對象的解構賦值必須要屬性名相同,順序毫無影響。數組解構賦值默認值,當等號右邊的值時,默認值生效。 let變量 let聲明的變量在let命令所在的代碼塊中有效。不存在變量提升,只能先聲明后使用。 暫存死區(qū) 如果區(qū)塊中存在let和const命令,這個區(qū)塊對這些命令聲明的變量,從一開始就形成了封閉作用域。凡是在聲明之前就使用這些變量。 var a = 1; { ...
摘要:不存在塊級作用域,具有變量提升機制。在同一作用域內只能聲明一次。注意其針對的是和所在的塊級作用域。在編程過程中如果需要變量提升則使用聲明變量,否則采用和聲明變量,以便更好地控制作用域,避免變量的混用不可控。 1、 var、let、const var不存在塊級作用域,具有變量提升機制。 let和const存在塊級作用域,不存在變量提升。在同一作用域內只能聲明一次。 ## var的說明 #...
摘要:聲明之函數作用域和全局作用域。塊級作用域不能重復聲明臨時性死區(qū)等特性用來解決變量存在的種種問題。塊級作用域終于在外面訪問不到了。一些常量聲明使用聲明的變量名全部大寫。 ES5之前javascript語言只有函數作用域和全局作用域,使用var來聲明變量,var聲明的變量還存在變量提升使人困惑不已。我們先來復習一下ES5的var聲明,再對比學習let和const 。 var var聲明之函...
閱讀 2686·2023-04-25 20:28
閱讀 1863·2021-11-22 09:34
閱讀 3694·2021-09-26 10:20
閱讀 1853·2021-09-22 16:05
閱讀 3094·2021-09-09 09:32
閱讀 2526·2021-08-31 09:40
閱讀 2108·2019-08-30 13:56
閱讀 3325·2019-08-29 17:01