您好,登錄后才能下訂單哦!
這篇文章主要講解了“JavaScript中的聲明提升是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“JavaScript中的聲明提升是什么”吧!
聲明提升(hosting)是 JavaScript 解析器的一個特性,它會把代碼中的函數、變量聲明語句作用提取到它所在作用域的最前面。
JavaScript 是支持在函數聲明之前調用函數的。
say();function say() { console.log("Hello");
}
解析器會掃描作用域內的代碼,把函數聲明提取到執行代碼的前面。所以,解析器是這樣看這段代碼的:
function say() { console.log("Hello");
}say();
除了普通函數,async function
, function *
, async function *
也有相同的提升效果。
var
變量聲明提升var
關鍵字的變量聲明會被提升,但變量的賦值不會被提升。
console.log(foo); // undefinedvar foo = "bar";console.log(foo); // 'bar'
以上代碼的解析結果為:
var foo;console.log(foo);
foo = "bar";console.log(foo);
這可能會導致一些奇怪的問題:
var x = "x in global";
(function () { // 這里期望讀取全局變量
console.log(x); // 結果為undefined.
/* ... */
// 在函數內某處
var x = "x in function";
})();
在過去,為了規避這種奇怪的提升,大家普遍把var
聲明寫在作用域的最前面。
var x='x';var y='y';function (){ var x; var foo; // ...}
當然,現在我們選擇不用 var
,改用更合理的 let
和 const
。
let
和 const
變量聲明和死區那么,let
和 const
就不存在變量提升了嗎?—— 未必。
看這個例子:
const x = "x in global";
(function () { // 這里期望讀取全局變量
console.log(x); // ReferenceError: Cannot access 'x' before initialization
/* ... */
// 在函數內某處
const x = "x in function";
})();
執行報錯,說明 const x = "x in function";
一行影響了作用域內的上方區域代碼。
解析器會掃描當前作用域下的 const
和 let
聲明,在聲明語句之前使用變量名都會觸發 ReferenceError
。這樣可以避免上面提過的 var
提升問題和模糊不清的代碼范式。
class
關鍵字也有同樣的效果,new
一個未聲明的類也會發生 ReferenceError
。
new MyClass(); // ReferenceError: Cannot access 'MyClass' before initializationclass MyClass {}
有人認為這種情況不屬于提升,畢竟聲明和賦值都沒有提前;也有人認為這些語句在執行之前就產生了影響,其作用提升了。個人偏向后者,這是對(變量和類名)標識符的提升。
感謝各位的閱讀,以上就是“JavaScript中的聲明提升是什么”的內容了,經過本文的學習后,相信大家對JavaScript中的聲明提升是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。