1.全域作用域
JavaScript中,在{}外面的作用域,我們就稱之為全域作用域
//全域作用域
var num1 = 123;
let num2 = 456;
if(...){
...
}
2.區域作用域
JavaScript中,在函式后面{}中的作用域,我們就稱之為區域作用域
//區域作用域
function test() {
console.log("Hello World!");
}
3.塊級作用域
JavaScript中,只要是沒有和函式結合在一起的{}中的作用域, 我們就稱之為塊級作用域
//塊級作用域
if (...) {
...
}
while (...) {
...
}
do {
...
}while (...)
4.注意點
-
在塊級作用域中,通過var定義的變數是全域變數,而通過let定義的變數是區域變數
if (true) { //全域變數var num1 = 123; //區域變數 let num2 = 456; } console.log(num1); console.log(num2);
-
在區域作用域中,通過var定義的變數是區域變數,通過let定義的變數也是區域變數
function test() { //區域變數 var num1 = 123; //區域變數 let num2 = 456; } test(); console.log(num1); console.log(num2);
-
無論是在塊級作用域還是在區域作用域中,省略定義變數的關鍵字let或var,那么該變數就會變為全域變數
if(true) { num1 = 123; num2 = 456; } function test() { num3 = 111; num4 = 222; } test(); console.log(num1); console.log(num2); console.log(num3); console.log(num4);
如有錯誤,還請評論指出
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/131630.html
標籤:JavaScript
上一篇:vue實作回傳頂部組件
