Prototype, prototype chain is also a platitude of the problem, it can be said that JS prototype figure out, then learning JS got a qualitative leap, today we will look at this in the front-end interview in the high frequency test question is what the matter.
A prototype,
JavaScript is often described as a prototype-based language — one prototype object per object
When it tries to access an object’s properties, it searches not only for that object, but also for that object’s prototype, and the prototype of that object’s prototype, working its way up until it finds an attribute with a matching name or reaches the end of the prototype chain
To be precise, these properties and methods are defined on prototype properties above the Object’s constructor functions, not on the instance Object itself
Prototype example:
Functions can have attributes. Each function has a special property called prototype
function doSomething(){}
console.log( doSomething.prototype );
Copy the code
Console output
{
constructor: ƒ doSomething (),__proto__: {
constructor: ƒ Object(),
hasOwnProperty: ƒ hasOwnProperty (),isPrototypeOf: ƒ isPrototypeOf (),propertyIsEnumerable: ƒ propertyIsEnumerable (),toLocaleString: ƒ toLocaleString (),toString: ƒ toString (),valueOfƒ valueOf()}}Copy the code
The object above is what we call a prototype object
As you can see, the prototype object has its own property constructor, which points to the function, as shown in the following diagram
Second, prototype chain
A stereotype object may also have a stereotype from which it inherits methods and properties, layer by layer, and so on. This relationship, often referred to as the Prototype chain, explains why one object has properties and methods defined in other objects
Establish a link between the object instance and its constructor (which is the __proto__ property, derived from the constructor’s prototype property), and then find those properties and methods in the constructor by going up the prototype chain
Prototype chain example:
function Person(name) {
this.name = name;
this.age = 18;
this.sayName = function() {
console.log(this.name); }}// Step 2 create an instance
var person = new Person('person')
Copy the code
Based on the code, we get the following figure
Here’s an analysis:
- The Person constructor has the prototype object Person.prototype
- The constructor generates the instance object Person, whose __proto__ points to the constructor Person prototype object
- Person.prototype.proto points to the built-in Object because Person.prototype is an Object that is created by default as a class by the Object function, while Object.prototype is the built-in Object
- Person.proto points to the built-in anonymous Function, because Person is a Function object, created by default by Function as a class
- Function.prototype and function. __proto__ both point to the built-in anonymous Function, so that the end of the prototype chain is null
Third, summary
Let’s start with a few concepts:
__proto__ acts as a bridge between different objects, pointing to the prototype object on which its constructor was created
Each object’s __proto__ refers to its constructor’s prototype object
person1.__proto__ === Person.prototype
Copy the code
A constructor is a Function object that is generated through the Function constructor
Person.__proto__ === Function.prototype
Copy the code
The prototype Object itself is an ordinary Object, and the constructors of ordinary objects are all Objects
Person.prototype.__proto__ === Object.prototype
Copy the code
As mentioned above, all constructors are Function objects, and Function objects are generated by Function constructs
Object.__proto__ === Function.prototype
Copy the code
Prototype objects of Object also have a __proto__ attribute pointing to NULL, which is the top of the prototype chain
Object.prototype.__proto__ === null
Copy the code
The last
This is the end of our prototype and prototype chain article, if the above content is wrong, please point out, I will correct in time. Learn from each other and make progress together. Thank you for your attention…
You can contact me at 714205369 for pre-school