Before we jump into what is scope in JS, we need to review some of concepts: Lexical Scope (Static Scope) and Dynamic Scope, but what is scope really?
What is Scope?
Imagine you’re at a big party in a huge mansion with multiple rooms. Each room has its own set of rules about what you can talk about and do. In programming, scope is like the “rules” for where certain things (like variables) can be seen and used.
Lexical Scope (Static Scope)
A portion of source code (area of text). The scope is determined when the programming language is interpreted, or we can say the scope is determined when the language defined the code.
Dynamic Scope
A portion of runtime (period during execution). The scope is determined when the code is executed.
Categories of Scope
We can simply category scopes, the global scope, the function scope and block scope, let's dive into it one by one.
1. Global Scope
Any variables declared in the global scope that can be accessed globally.We can access variables inside a function or outside a function.
2. Function Scope
Any variables declared inside the function that can only be accessed within the function.
3. Block Scope
Variables declared using let and const, the variables are only accessible within the block they are declared in.
Comparison with var
Variables declared using var are not limited to block scope, but they do have function scope and global scope. The reason why using var can still be accessed in block-scope is because the concept that we've mentioned above.
Imagine the code like this, it seemed var variable was hoisted like below.
But what happened behind the scene was JS read codes first and executed afterwards, remember the 2 phases when JS created the global execution context? Creation phase:
- Stored variable greeting and initialized the value of undefined. Execution phase:
- Executed the code, assign the value of "Hello World!" to variable greeting.
Summary
-
There're three scopes in JS:
- Global Scope
- Function Scope
- Block Scope
Global Scope:
Any variable or function declared outside of any function, block, or module resides. Variables and functions in the global scope can be accessed from anywhere in the code, see example below.
Function Scope:
Any variable or function declared inside a function is accessible only within that function and is not accessible from outside it. This is also known as local scope.
- Take a look the code below, do you know the answer?
Block Scope:
The scope of variables declared with let and const within a block (a pair of curly braces {}
). These variables are only accessible within the block they are declared in and are not accessible from outside that block.
When is Scope Determined?
Scope is determined at the time the code is written. In JavaScript, whenever you create a new function or code block (such as if, for, while, etc.), a new lexical scope is created. These scopes are determined before the code is executed.