A brief discussion on JS prototype and prototype chain

A brief discussion on JS prototype and prototype chain

1. Prototype

All functions in JavaScript have this property, and all objects with a prototype property are functions. The purpose of prototype is to add a method/property to an object.

function persistence(){}
persion.prototype.name = "xiaoming"
console.log(persion.prototype)//{name: "xiaoming", constructor: ƒ}

2. Prototype pointer: __proto__

If the above persion function generates an instance object Persion1, and uses prototype to add an attribute to it, the writing is as follows:

function persistence(){}
persion.prototype.name = "xiaoming"
let Persion1 = new Persion();
console.log(Persion1) //The console results are as follows

The results of printing instance Persion1 are as follows:

From the results printed above, Persion1.__proto__.name = persion.prototype.name, that is, the __proto__ attribute of the instance object is equal to the prototype of its constructor.

After understanding the above, the prototype chain is easy to understand. We can directly find the Object method through Persion1.__proto__.__proto__. This may not be very intuitive, here is the code:

function persistence(){}
persion.prototype.name = "xiaoming"
let Persion1 = new Persion();
console.log(Persion1.__proto__.__proto__.toString) //The toString method of Object found through the prototype chain console.log(Object.prototype.toString) //The toString method on Object

The console prints the following results, which confirms the level-by-level search feature of the prototype chain.

Summarize

Any object can be searched level by level through the prototype chain, that is, the __proto__ attribute. The final focus is Object, and the only way is function. Their relationship is like a chain, and we call this relationship a prototype chain.

The above is a brief discussion of the details of JS prototype and prototype chain. For more information about JS prototype and prototype chain, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Detailed explanation of JavaScript prototype chain
  • JavaScript prototype and prototype chain details
  • Thoroughly understand JavaScript prototype and prototype chain
  • Understanding JavaScript prototype chain
  • JS Difficulties Synchronous and Asynchronous and Scope and Closure and Detailed Explanation of Prototype and Prototype Chain
  • Comprehensive analysis of prototypes, prototype objects, and prototype chains in js
  • Detailed explanation of prototypes and prototype chains in JavaScript

<<:  In-depth analysis of MySQL execution plans

>>:  VMware15 installation of CentOS7 detailed process and common problems (picture and text)

Recommend

MySQL 5.7 generated column usage example analysis

This article uses examples to illustrate the usag...

Detailed explanation of MySQL DEFINER usage

Table of contents Preface: 1.Brief introduction t...

MySQL backup and recovery design ideas

background First, let me explain the background. ...

Nginx implements https website configuration code example

https base port 443. It is used for something cal...

Tomcat server security settings method

Tomcat is an HTTP server that is the official ref...

Detailed tutorial on installing CentOS, JDK and Hadoop on VirtualBox

Table of contents 1. Prerequisites 1.1 Supported ...

React implements the addition, deletion, modification and query of todolist

Table of contents Take todolist as an example The...

How to build your own Angular component library with DevUI

Table of contents Preface Creating a component li...

Example of deploying Laravel application with Docker

The PHP base image used in this article is: php:7...

Public free STUN servers

Public free STUN servers When the SIP terminal us...

jQuery implements the bouncing ball game

This article shares the specific code of jQuery t...

In-depth study of vue2.x--Explanation of the h function

Table of contents Solution, Summarize: vue projec...

Detailed explanation of the reasons why MySQL connections are hung

Table of contents 1. Background Architecture Prob...