


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!

The main difference between Python and JavaScript is the type system and application scenarios. 1. Python uses dynamic types, suitable for scientific computing and data analysis. 2. JavaScript adopts weak types and is widely used in front-end and full-stack development. The two have their own advantages in asynchronous programming and performance optimization, and should be decided according to project requirements when choosing.

Whether to choose Python or JavaScript depends on the project type: 1) Choose Python for data science and automation tasks; 2) Choose JavaScript for front-end and full-stack development. Python is favored for its powerful library in data processing and automation, while JavaScript is indispensable for its advantages in web interaction and full-stack development.

Python and JavaScript each have their own advantages, and the choice depends on project needs and personal preferences. 1. Python is easy to learn, with concise syntax, suitable for data science and back-end development, but has a slow execution speed. 2. JavaScript is everywhere in front-end development and has strong asynchronous programming capabilities. Node.js makes it suitable for full-stack development, but the syntax may be complex and error-prone.

JavaScriptisnotbuiltonCorC ;it'saninterpretedlanguagethatrunsonenginesoftenwritteninC .1)JavaScriptwasdesignedasalightweight,interpretedlanguageforwebbrowsers.2)EnginesevolvedfromsimpleinterpreterstoJITcompilers,typicallyinC ,improvingperformance.

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.

The power of the JavaScript framework lies in simplifying development, improving user experience and application performance. When choosing a framework, consider: 1. Project size and complexity, 2. Team experience, 3. Ecosystem and community support.

Introduction I know you may find it strange, what exactly does JavaScript, C and browser have to do? They seem to be unrelated, but in fact, they play a very important role in modern web development. Today we will discuss the close connection between these three. Through this article, you will learn how JavaScript runs in the browser, the role of C in the browser engine, and how they work together to drive rendering and interaction of web pages. We all know the relationship between JavaScript and browser. JavaScript is the core language of front-end development. It runs directly in the browser, making web pages vivid and interesting. Have you ever wondered why JavaScr


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Dreamweaver CS6
Visual web development tools

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

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