


Why do you need to use JavaScript to implement inheritance? Detailed explanation of examples of several inheritance methods
Why you need to use javascript to implement inheritance
The performance of early PC machines is really not flattering. All the pressure is on the server side, and the client browser is purely for decoration. Coupled with the popular table layout and telephone line Internet access at that time, browsing a web page was very slow; now the Internet era is developing rapidly, personal computer hardware has been greatly improved, and the performance of client browsers is also very disappointing. The model of web development is also quietly changing: the server is no longer as "hard" as before. Instead, the browser should take on as many tasks as possible. In this way, the pressure is distributed to each client. Not only does the enterprise Saving costs also makes web front-end development more interesting - more and more front-end frameworks are emerging, and even many front-end MVC frameworks have emerged. In this context, the role of JavaScript is definitely not just to do some simple verification, send some requests or operate some DOM. It needs to play more roles like front-end routing and business layer, and JavaScript needs to do a lot of logical tasks. , which includes the abstraction of front-end data (i.e. model), and only by using object-oriented thinking can the abstracted data be processed well, so inheritance is very important here.
Now extract a model named Person from the front desk, which has basic attributes name and age. By default, everyone can speak, so the speaking function is placed on the prototype object for each instance to enjoy. . Now for Man, it needs to inherit the basic attributes of Person and add its own unique attributes on this basis.
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man() { //my own properties }
Several mainstream inheritance methods:
1. Prototype chain inheritance
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man() { } Man.prototype = new Person('pursue'); var man1 = new Man(); man1.say(); //hello, my name is pursue var man2 = new Man(); console.log(man1.say === man2.say);//true console.log(man1.name === man2.name);//true
This inheritance method is very direct. In order to obtain all attribute methods of Person (instances and prototypes), directly assign the instance of the parent class new Person('pursue') Given the prototype of the subclass, in fact, the subclass instances man1 and man2 themselves are completely empty objects. All attributes and methods have to be found on the prototype chain, so the attributes and methods found are the same.
So it is unrealistic to directly use prototype chain inheritance.
2. Use constructor inheritance
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } //Man.prototype = new Person('pursue'); var man1 = new Man('joe'); var man2 = new Man('david'); console.log(man1.name === man2.name);//false man1.say(); //say is not a function
Here the subclass uses apply in the constructor to call the parent class Constructor, so as to achieve the effect of inheriting the properties of the parent class, is much better than directly using the prototype chain. At least each instance has its own share of resources. However, this method can only inherit the instance properties of the parent class, so it cannot be found. Say method, in order to inherit all properties and methods of the parent class, the prototype chain must be modified, thus introducing the combined inheritance method.
3. Combined inheritance
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } Man.prototype = new Person(); var man1 = new Man('joe'); var man2 = new Man('david'); console.log(man1.name === man2.name);//false console.log(man1.say === man2.say);//true man1.say(); //hello, my name is joe
It should be noted that the instance attributes of man1 and man2 actually override the prototype attributes, but There is no need to override the say method on the prototype (because they don't have it), so here man1.say === man2.say still returns true, so you need to be very careful about the prototype property that is not overridden, because it is common to all instances.
4. Parasitic combination inheritance
To be honest, I really don’t know the name of the following form, but it is indeed the most popular and classic one JavaScript inheritance method. In fact, you only need to understand the structure of the prototype object:
function Person (name, age) { this.name = name; this.age = age; } Person.prototype.say = function(){ console.log('hello, my name is ' + this.name); }; function Man(name, age) { Person.apply(this, arguments); } Man.prototype = Object.create(Person.prototype);//a. Man.prototype.constructor = Man;//b. var man1 = new Man('pursue'); var man2 = new Man('joe'); console.log(man1.say == man2.say); console.log(man1.name == man2.name);
In fact, the only difference between parasitic combination inheritance and the above combination inheritance is the way to construct the prototype object of the subclass Above (a. and b.), the Object.creat(obj) method is used here, which will make a shallow copy of the incoming obj object, similar to:
function create(obj){ function T(){}; T.prototype = obj; return new T(); }
Therefore, a. The prototype object of the subclass will be well connected with the prototype object of the parent class, instead of directly copying the prototype of the subclass (such as Man.prototype = new Person();), this is just a very violent overwriting of properties. The parasitic combination inheritance method inherits instance attributes and prototype attributes separately, which is more reasonable in implementation.
Note: Code b. will not change the result of instanceof, but for scenarios where construcor is required, this is more rigorous.
The above is the detailed content of Why do you need to use JavaScript to implement inheritance? Detailed explanation of examples of several inheritance methods. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The speed of mobile XML to PDF depends on the following factors: the complexity of XML structure. Mobile hardware configuration conversion method (library, algorithm) code quality optimization methods (select efficient libraries, optimize algorithms, cache data, and utilize multi-threading). Overall, there is no absolute answer and it needs to be optimized according to the specific situation.

The difference between string printing in Go language: The difference in the effect of using Println and string() functions is in Go...

Go pointer syntax and addressing problems in the use of viper library When programming in Go language, it is crucial to understand the syntax and usage of pointers, especially in...

Why does map iteration in Go cause all values to become the last element? In Go language, when faced with some interview questions, you often encounter maps...

XML Online Format Tools automatically organizes messy XML code into easy-to-read and maintain formats. By parsing the syntax tree of XML and applying formatting rules, these tools optimize the structure of the code, enhancing its maintainability and teamwork efficiency.

Go language slice index: Why does a single-element slice intercept from index 1 without an error? In Go language, slices are a flexible data structure that can refer to the bottom...

Modifying XML content requires programming, because it requires accurate finding of the target nodes to add, delete, modify and check. The programming language has corresponding libraries to process XML and provides APIs to perform safe, efficient and controllable operations like operating databases.

The logical non-operator (!) has the priority next to parentheses, which means that in expressions, it will precede most other operators. Understanding priority not only requires rote memorization, but more importantly, understanding the logic and potential pitfalls behind it to avoid undetectable errors in complex expressions. Adding brackets can clarify expression intent, improve code clarity and maintainability, and prevent unexpected behavior.
