


Detailed explanation of javascript inheritance mechanism examples_javascript skills
The examples in this article describe the JavaScript inheritance mechanism. Share it with everyone for your reference. The specific analysis is as follows:
It is generally difficult for beginners to understand the inheritance mechanism of Javascript language. There is no concept of "subclass" and "parent class", and there is no distinction between "class" and "instance". It all relies on one A very peculiar "prototype chain" model to implement inheritance.
I spent a lot of time studying this part and took a lot of notes. But they are all forced memories and cannot be understood fundamentally.
1. How to create a class
Suppose there is a class called Person as follows:
This.name = name;
This.age = age;
}
Person.prototype.getName = function() {
Return this.name;
}
As above: Person represents all people on the earth, and everyone has these two basic attributes: name and age; now we have to implement a student class, and then we know; a student is also a person, and students also have attributes such as name and age. ;The question now is how to establish this relationship?
Let’s first take a look at how a pure object-oriented language does it (such as: Actionscrpt3)
2. How to do it by switching to js
Before explaining the implementation of the inheritance mechanism of js, let’s first understand the prototype chain of js:
person.getName(); // "Poised-flw"
As for the getName() method above, how is it executed? First, I will look for the getName() method in the Person function and find that there is not; then I will go to Person.prototype to search and find that there is! Then call it, what if not? Continue searching along the prototype in the same way until you find a method or reach the top of the prototype chain!
For example, there is now a constructor called DOG, which represents the prototype of the dog object.
this.name = name;
}
Using new on this constructor will generate an instance of the dog object.
alert(dogA.name); // Da Mao
Pay attention to the this keyword in the constructor, which represents the newly created instance object.
3. Disadvantages of new operator
Using a constructor to generate instance objects has a disadvantage, that is, properties and methods cannot be shared.
For example, in the constructor of the DOG object, set the common attributes species of an instance object.
this.name = name;
this.species = 'Canidae';
}
Then, generate two instance objects:
var dogB = new DOG('二毛');
The species attributes of these two objects are independent, and modifying one will not affect the other.
alert(dogB.species); // Display "canine", not affected by dogA
Each instance object has its own copy of properties and methods. This not only fails to achieve data sharing, but is also a huge waste of resources.
So: The idea of inheritance: Implement the inheritance mechanism through the unique prototype chain of js!
4. Inheritance based on prototype chain
1. Direct inheritance implementation
Person.call(this, name, age);
This.sid = sid;
}
Students.prototype = new Person(); //Put Person on the prototype chain of Students to implement the inheritance mechanism
Students.prototype.constructor = Students;
Students.prototype.getResults = function() {
// Get student scores
}
Be sure not to miss the line Students.prototype.constructor = Students! , when defining a constructor, its default prototype is an Object instance, and then the constructor property of the prototype is automatically set to the function itself! ! ! If the prototype is manually set to another object, the new object will naturally not have the constructor value of the original object, so its constructor property needs to be reset. Such as:
This.time = "now";
}
console.log(Test.prototype); // Object {} an empty object
console.log(Test.prototype.constructor); // function() {this.time = "now";}, and the function itself
// If you manually change the prototype attribute of Test
Test.prototype = {
SomeFunc: function() {
console.log('hello world!');
}
};
console.log(Test.prototype.constructor); // function Object() { [native code] }
// Then you will find that you pointed it completely wrong, so when you manually change the prototype attribute, you need to change its constructor pointer;
After the above test, you will know why the constructor value needs to be modified.
2. Encapsulate inherited functions extend
var F = function() {};
F.prototype = superClass.prototype;
subClass.prototype = new F();
subClass.prototype.constructor = subClass;
}
In fact, the function of this function is just an encapsulation of the above inheritance process. The differences are:
It only inherits the prototype attribute of superClass and does not inherit the attributes in the superClass constructor;
The advantage of this is that it reduces the cost of creating a new constructor!
Of course, the subsequent problem is that subClass cannot inherit all attributes of superClass through this function alone
Improvements:
Person.call(this, name, age);
5. Summary
Using the prototype chain principle of js, we can easily implement the inheritance mechanism of js. Although it is not very strict, my goal has been achieved: repeated code should appear once as much as possible!
I hope this article will be helpful to everyone’s JavaScript programming design.

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

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Atom editor mac version download
The most popular open source editor

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