Home  >  Article  >  Web Front-end  >  The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

php是最好的语言
php是最好的语言Original
2018-07-28 10:06:142755browse

JS Detailed explanation of scope and scope chain: Recommend an article http://www.php.cn/js-tutorial-8031.html

It’s a difficult sentence to understand. Here's a look: When code is executed in an environment, a scope chain of variable objects is created. The purpose of the scope chain is to ensure ordered access to all variables and functions that the execution environment has access to

Scope: The scope of a variable is the one defined in the program source code variable area. (Note that the scope of a variable is determined when the variable is defined, not when a method is executed)

es5 has two scopes, function scope and global scope

Each piece of JavaScript code (global code or function) has a scope chain associated with it.

This scope chain is a list or linked list of objects. This group of objects defines the variables "in scope" in this code.

When js needs to find the value of variable x (this process is called variable resolution), it will start searching from the first object in the chain. If this object has an object named x attribute, the value of this attribute will be used directly. If there is no attribute named x in the first object, js will continue to search for the next object in the chain. If the second object still does not have an attribute named x, it will continue to look for the next one, and so on. If no object in the scope chain contains attribute x, then it is considered that x does not exist in the scope chain of this code, and eventually a ReferenceError exception is thrown.

Summary: The function of the scope chain is that for variables, you can find the value according to this chain. You can only search upwards. If you find the first one, you will no longer search. This scope and the scope chain are both It is determined when the variable is defined, regardless of the order of execution.

Some questions:

The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

The execution result of this code is 3, because when function c is defined, it constitutes a scope, and its previous The scope is the global one, not the self-executing function (

The scope and scope chain are determined when the variable is defined, and have nothing to do with the order of execution.

)

The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

The reason why i can be printed outside the for statement in this question is because the js statement does not constitute a scope, and its scope still belongs to the global world. Changing var to let will Report an error, try

The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

#This question is relatively comprehensive. I have to understand it carefully many times before I understand it. It is worth studying, so I won’t write an explanation first. . think. . .

The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

This question requires a good understanding of the prototype chain. The running result is 2018072717455864The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]

Related articles:

js Scope chain, prototype chain and prototype inheritance

Detailed explanation of js prototype and prototype chain

Related videos:

JavaScript advanced framework design video tutorial

The above is the detailed content of The understanding of prototype chain and scope chain in js and the problem of this pointing [Picture]. For more information, please follow other related articles on the PHP Chinese website!

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