The preface
Prototypes and prototype chains are a cliche. First of all, prototype and prototype chain belong to the high order category of JS language, which is also the cornerstone of JS language. I believe many friends have seen a variety of tutorials and interpretation, this time we dig from a different Angle.
Introduction to Basic Concepts
The function and the function
In JS, function is a keyword used to declare a function object.
// Function Declaration
function f(){};
// Function Expression)
const f = function(){};
// new Function constructor
// It is not recommended to declare Function objects as Function objects
// The code will be parsed again when adding attributes to the object (writing its methods)
const f = new Function(a);Copy the code
Among them, the difference between function expression and function declaration, interested in their own reference
New Function() creates the corresponding Function object. Only Function objects have a prototype object. Any object must have an implicit prototype __proto__.
The prototype
The father of JS follows the following two principles when designing JS prototypes and prototype chains:
function Person() {}const person = new Person()
Rule 1: The constructor of the prototype object (person.prototype) points to the constructor itself
Person.prototype.constructor === Person
// Rule 2: The __proto__ of an instance (i.e. person) points to the same place as the prototype object
person.__proto__ === Person.prototype
// Every object has a __proto__ attribute, but only function objects have a prototype attribute
Copy the code
The __proto__ES5 standard uses [[prototype]] to refer to the prototype object. The prototype object refers to the prototype
Prototype chain
When it comes to the prototype chain, you have to take out the family
Overall prototype chain analysis
Let’s first draw the bottom implementation order conclusion of the prototype chain
Object. Prototype is the first Object created in js. Then: Create the Function. Prototype prototype object based on this prototype object. Second: create Function from the prototype object. Finally, Object () is created by using Function.Copy the code
Prototype objects and custom constructors have __proto__ that points to Object. Prototype objects are normal objectsCopy the code
A lot of prototype chain explanation is from the shallow into the deep, today we will have depth to explain, some instructions will find the basis from the above prototype chain diagram. The Object’s __proto__ prototype is null. The js engine created Object. Prototype so this Object’s prototype is null. Prototype then builds the Function. Prototype Object from object. prototype. Function via new Function (so points it is own proto!) This paragraph. Function is the special Function object whose __proto__ refers to function. prototype indicating that it built itself. Object is created using new Function ().
Object and Function are the two most important constructors in JS, because all complex types in JS are built by them as the cornerstone. It is very easy to understand these two constructor prototype chain.
Because I am in the process of learning prototype and prototype chain is never understand thoroughly the Function and the Object that, when the feeling is very round, because there is no dig in, use less also ready to explore the elementary knowledge review recently, what are the complementary and controversial place welcome friend, personal habits and understand the language, Hope to understand.