First, we need to know the concept of scope
1. What is scope?
The region or set in which variables (variables act on a context) and functions are in effect (can be accessed). In other words, a scope determines the visibility of variables and other resources in a block of code. Let’s look at an example:
function myFunction() {
let inVariable = "Internal variables of the function"; } myFunction(); // This function must be executed first, otherwise you will not know what is inside console.log(inVariable); // Uncaught ReferenceError: inVariable is not defined
Copy the code
As you can see from the example above, we created a function myFunction and created a variable inVariable inside the function. When we accessed this variable globally, the system reported an error. This means that we can’t get variables inside functions globally (except for closures). We can think of it this way: the scope is an independent site, so that variables do not leak out, exposed. In other words, the greatest use of a scope is to isolate variables. Variables of the same name in different scopes do not conflict.
Global scope and function scope
Objects that can be accessed anywhere in your code have a global scope. In general, the following situations have a global scope
-
Outermost functions and variables defined outside the outermost function have global scope.
let outVariable = I'm an external variable;
function outFunction() {
let inVariable = "I'm an internal variable.";
function inFunction() {// I am the internal function console.log()inVariable);
}
inFunction(); } console.log(outVariable); // I am the external variable outFunction(); // I'm console.log(inVariable); //inVariable is not defined
inFunction(); //inFunction is not defined
Copy the code
-
All variables that do not define a direct assignment are automatically declared to have a global scope
function outFunction() {
variable = "Variable with no direct assignment defined";
var inVariable = "I'm an internal variable."; } outFunction(); Console. log(variable); console.log(variable); // For variables that are not directly assigned, there will be a "variable promotion" console.log(inVariable); //inVariable is not defined
Copy the code
In the above code, variable is assigned to the function outFunction before it is defined, which promotes the variable to the global scope. Promotion occurs during the precompilation phase of a function, which means that any variable that is assigned an undeclared value is owned by the global object. Variable promotion is also called implied global variables.
-
All properties of window objects have global scope
In general, the built-in properties of a window object have global scope, such as window.name and window.location
-
Function scope
The scope of a variable or method declared inside a function is the scope of the function. Is not accessible outside the function (unless required).
function doSomething(){ var blogName="Boat on the waves."; function innerSay(){ alert(blogName); } innerSay(); } alert(blogName); //VM1210:8 Uncaught ReferenceError: blogName is not defined innerSay(); //VM1210:8 Uncaught ReferenceError: innerSay is not defined Copy the code
You can see that variables or functions declared inside the function in the above code are not accessible outside the function, indicating that variables or methods defined inside the function are only function scopes.
2. What is a scope chain?
Before we talk about scope chains we need to know the concept [[scope]]
-
[[scope]]
Remember that every function in JavaScript is an object, and there are properties in the object that we can access, and properties that we can’t access, and those properties are only accessed by the JavaScript engine. [[scope]] is one of them. . [[scope]] refers to what we call the scope, which storesRuntime contextThe collection.
-
Runtime context
When a function executes, an internal object called the execution-time context is created. An execution-time context defines the context in which a function is executed. Each time a function is executed, the corresponding execution context is unique. Therefore, multiple calls to a function result in the creation of multiple execution contexts, which are destroyed when the function completes execution.
-
The scope chain
[[scope]] is a collection of execution context objects stored in [[scope]. This collection is linked in a chain called a scope chain.
Second, scope elaboration
Let’s take a look at scope in detail with a piece of code
function a() {
function b() {
var b = 234;
}
var a = 123;
b();
}
var gloab = 100;
a();
console.log(gloab);
console.log(b);
console.log(a)
Copy the code
We all know that JavaScript code goes through a process called precompilation before it can be executed, as we mentioned earlier. So let’s do this step by step.
Step 1: a function definition
As can be seen from the figure above, when a function is defined, the scope of the attribute [[scope]] of a function Object points to its scope chain. At this time, the first item of its scope chain points to the GO(Global Object) Global Object. We can see that there are five properties on the Global Object at this time. They are this, Window, document, a and glob.
Step 2: function A is executed
Step 3: B function definition
Step 4: b function execution
This is the result of executing the code above. When we access the variables, we look up from the bottom of the scope chain.
Glob is not found on the first term of the scope chain. The second term is not found on the second term. The third term is found in GO.
Secondly, variable B is searched. The first item in the scope chain is searched and variable B is found. The value of the final variable B is 234.
I’m going to look for variable A, and I’m not going to find it on the first term of the scope chain and I’m going to look for variable A on the second term, and I’m going to find variable A, which is 123.
conclusion
So that’s pretty much it for JavaScript scopes and scope chains, and I’ll talk about closures and precompilation. If you have other different understanding or suggestions, please leave a message below. If there is an incorrect understanding of the place also please give advice.