search
HomeWeb Front-endJS TutorialIn-depth understanding of scope and context in Javascript_javascript skills

Overview

The implementation of scope and context in Javascript is a unique feature of the Javascript language. To a certain extent, the Javascript language is very flexible. Functions in Javascript can take on a variety of contexts, and scopes can be encapsulated and saved. It is precisely because of these characteristics that Javascript also provides many useful design patterns. However, scope and context are also areas where Javascript programmers often get confused during development.
The following will introduce to you the concepts of scope and context in Javascript, as well as their differences.

Scope VS Context

The first important thing to note is that scope and context are not the same concepts, and they do not refer to the same thing. As a front-end geek, I often see articles that confuse these two concepts. As a result, some things become less clear the more I read them. These two concepts seem to have been confused for a long time. Therefore, I checked a lot of information and briefly explained these two concepts. :stuck_out_tongue_closed_eyes:
In Javascript, when a function is called, there is a scope and context bound to the function. Fundamentally, scope is function-based and context is object-based. In other words, scope applies to access to variables within a function when the function is called. Context usually refers to the value of the "this" keyword, which is a reference to the object that owns the currently executing code.

Variable scope

Variables can be defined in the local or global scope, called local variables and global variables respectively. Global variables refer to variables declared outside the function. Global variables can be accessed anywhere in the program. Local variables refer to variables defined within the function body. They can only be accessed within the function body or nested functions, and cannot be accessed outside the function.
Javascript currently does not support block-level scope (variables defined in if, switch, for, etc. statements). This means that variables defined inside a block can also be accessed outside the block. However, in ES6, we can define block-level scope using the "let" keyword.
Regarding the content of the scope, you can check other information. This part of the content is relatively simple.

"this" context

Context usually depends on how the function is called. When a function is called as a method on an object, "this" refers to the object on which the function was called.

Copy code The code is as follows:

var obj={
foo:function (){
console.log(this === obj);
}
};
obj.foo(); //Output true

Similarly, when we use the "new" keyword to create a new object, this refers to the newly created object.
Copy code The code is as follows:

function foo(){
console.log(this);
}
foo(); //Output window
var obj=new foo(); //Output foo {}

One thing to note is that when a function in the global scope is called, this refers to the global object, which in the browser environment refers to window. However, when running the code in strict mode, "this" is set to "undefined"
Execution Context

Javascript is a single-threaded language, which means that when Javascript is running in the browser, it can only do one thing at a time, and other things will be queued in the method, waiting to be processed.

1. When the Javascript code file is loaded by the browser, the latest entry is a global execution context by default. When a function is called in the global context, the program enters the called function, and the Javascript engine creates a new execution context for the function and pushes it to the top of the execution context stack. The browser always executes the context currently at the top of the stack. Once execution is complete, the context is popped from the top of the stack and then executes code in the context below it. In this way, the contexts in the stack will be executed sequentially and popped off the stack until returning to the global context.

2. An execution context can be divided into two phases: creation phase and execution phase. In the creation phase, the JavaScript interpreter first creates a variable object (also called an "activation object"). Active objects consist of variables, function declarations and parameters. At this stage, the function's scope chain is initialized and the object referenced by this is also determined. Next comes the execution phase, where the code is interpreted and executed.
In Javascript code, there can be any number of function contexts. We already know that when a function is called, the Javascript interpreter will create a new context and a private scope. Any variables declared inside the function will be It cannot be accessed directly outside the scope of the current function.

3. Through the above explanation, we have a basic concept of the "execution context" of the function, but this is also the place where everyone is most confused. The "execution context" in Javascript mainly refers to the scope, not the "this context" referred to in the fourth section above. There are many similar confusing concepts in Javascript, but as long as we understand the specific object that each concept refers to, we will no longer be confused. Therefore, I also hope that everyone can truly distinguish "execution context". and "this context".

In a simple sentence, execution context is a concept related to scope, although this may not be rigorous.

Scope chain

For each execution context, there is a scope bound to it. The scope chain contains the execution context activation object (which sounds a bit convoluted) in the execution context stack. The scope chain determines access to variables and resolution of identifiers.

Code example:

Copy code The code is as follows:

function first(){
Second();
Function second(){
        third();
         function third(){
            fourth();
             function fourth(){
//Code
            }
}
}
}
first();

Execute the above code, and the nested functions will be executed. As far as the above code is concerned, a scope chain will also be formed. The order of the scope chain from top to bottom is: fourth, third, second, first, global. Function fourth can access variables in the global scope and can access any variables defined in functions third, second, and first.
One thing to note is that within the function body, local variables have higher priority than global variables with the same name. If a local variable declared within a function or a variable contained in a function parameter has the same name as a global variable, the global variable will be overwritten by the local variable.
To put it simply, every time we try to access a variable, the program will search for the variable in the scope of the current function. If it cannot be found, it will search along the scope chain to the upper level of the function until the variable is found. If it cannot be found, Returns undefined.

Summary

This article introduces the related concepts of context and scope in javascript. There are also several more important concepts in javascript, such as closures, etc. If you understand these in the future, you will write an article~~

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

20+道必知必会的Vue面试题(附答案解析)20+道必知必会的Vue面试题(附答案解析)Apr 06, 2021 am 09:41 AM

本篇文章整理了20+Vue面试题分享给大家,同时附上答案解析。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor