


Detailed explanation of JavaScript inheritance (1)_js object-oriented
Object-oriented and object-based
Almost every developer has development experience in object-oriented languages (such as C, C#, Java). In traditional object-oriented languages, there are two very important concepts - classes and instances. A class defines the public behaviors and methods of a class of things; and an instance is a specific implementation of the class. We also know that object-oriented programming has three important concepts - encapsulation, inheritance and polymorphism.
But in the world of JavaScript, all these features don’t seem to exist. Because JavaScript itself is not an object-oriented language, but an object-based language. There are some interesting features here. For example, everything in JavaScript is an object, including strings, arrays, dates, numbers, and even functions, such as the following example:
// 定义一个函数 - add<BR> function add(a, b) {<BR> add.invokeTimes++;<BR> return a + b;<BR> }<BR> // 因为函数本身也是对象,这里为函数add定义一个属性,用来记录此函数被调用的次数<BR> add.invokeTimes = 0;<br><br> add(1 + 1);<BR> add(2 + 3);<BR> console.log(add.invokeTimes); // 2<BR>
Simulate classes and inheritance in JavaScript
In object-oriented languages, we use classes to create a custom object. However, everything in JavaScript is an object. So how to create a custom object?
This requires the introduction of another concept - prototype. We can simply regard prototype as a template. The newly created custom objects are all copies of this template (prototype) (actually not copies but It’s a link, but this link is invisible and feels like a copy).
Let’s look at an example of creating a custom object via prototype:
// 构造函数<BR> function Person(name, sex) {<BR> this.name = name;<BR> this.sex = sex;<BR> }<BR> // 定义Person的原型,原型中的属性可以被自定义对象引用<BR> Person.prototype = {<BR> getName: function() {<BR> return this.name;<BR> },<BR> getSex: function() {<BR> return this.sex;<BR> }<BR> }<BR>
Here we call the function Person a constructor, which is a function that creates a custom object. It can be seen that JavaScript simulates the functions of classes through constructors and prototypes.
Code to create a custom object (instantiated class):
var zhang = new Person("ZhangSan", "man");<BR> console.log(zhang.getName()); // "ZhangSan"<br><br> var chun = new Person("ChunHua", "woman");<BR> console.log(chun.getName()); // "ChunHua"<BR>
When the code var zhang = new Person("ZhangSan", "man") is executed, the following things are actually done internally:
- Create a blank object (new Object()).
- Copy the attributes (key-value pairs) in Person.prototype to this empty object (as we mentioned earlier, the internal implementation is not a copy but a hidden link).
- Pass this object into the constructor through the this keyword and execute the constructor.
- Assign this object to variable zhang.
In order to prove that the prototype template is not copied into the instantiated object, but is a way of linking, please see the following code:
function Person(name, sex) {<BR> this.name = name;<BR> this.sex = sex;<BR> }<BR> Person.prototype.age = 20;<br><br> var zhang = new Person("ZhangSan", "man");<BR> console.log(zhang.age); // 20<BR> // 覆盖prototype中的age属性<BR> zhang.age = 19;<BR> console.log(zhang.age); // 19<BR> delete zhang.age;<BR> // 在删除实例属性age后,此属性值又从prototype中获取<BR> console.log(zhang.age); // 20<BR>
This hidden prototype link implemented within JavaScript is the warm soil on which JavaScript depends, and is also the basis for simulation implementation inheritance.
How to implement simple inheritance in JavaScript?
The following example will create an employee class Employee, which inherits all the properties in the prototype prototype from Person.
function Employee(name, sex, employeeID) {<BR> this.name = name;<BR> this.sex = sex;<BR> this.employeeID = employeeID;<BR> }<BR> // 将Employee的原型指向Person的一个实例<BR> // 因为Person的实例可以调用Person原型中的方法, 所以Employee的实例也可以调用Person原型中的所有属性。<BR> Employee.prototype = new Person();<BR> Employee.prototype.getEmployeeID = function() {<BR> return this.employeeID;<BR> };<br><br> var zhang = new Employee("ZhangSan", "man", "1234");<BR> console.log(zhang.getName()); // "ZhangSan<BR>
The above implementation of inheritance is very rough and has many problems:
- Person is instantiated when creating the Employee constructor and prototype (hereinafter referred to as the class), which is inappropriate.
- The constructor of Employee cannot call the constructor of the parent class Person, resulting in repeated assignment of the name and sex attributes in the Employee constructor.
- The function in Employee will overwrite the function of the same name in Person, and there is no overloading mechanism (this is the same type of problem as the previous one).
- The syntax for creating JavaScript classes is too fragmented and not as elegant as the syntax in C#/Java.
- There is a pointing error in the constructor attribute in the implementation, which will be discussed in the second article.
We will improve this example in Chapter 3.
Implementation of JavaScript inheritance
Because JavaScript itself does not have a complete implementation of classes and inheritance, and we have also seen many problems with manual implementation, there are already many implementations of this challenging task on the Internet:
- Douglas Crockford - Prototypal Inheritance in JavaScript
- Douglas Crockford - Classical Inheritance in JavaScript
- John Resig - Simple JavaScript Inheritance
- Dean Edwards - A Base Class for JavaScript Inheritance
- Prototype
- Mootools
- Extjs
This series of articles will analyze these implementations in depth one by one, and ultimately achieve an in-depth understanding of how classes and inheritance are implemented in JavaScript.
In the next chapter, we will introduce relevant knowledge in class implementation, such as this, constructor, prototype, etc.

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

In function inheritance, use "base class pointer" and "derived class pointer" to understand the inheritance mechanism: when the base class pointer points to the derived class object, upward transformation is performed and only the base class members are accessed. When a derived class pointer points to a base class object, a downward cast is performed (unsafe) and must be used with caution.

Inheritance and polymorphism affect the coupling of classes: Inheritance increases coupling because the derived class depends on the base class. Polymorphism reduces coupling because objects can respond to messages in a consistent manner through virtual functions and base class pointers. Best practices include using inheritance sparingly, defining public interfaces, avoiding adding data members to base classes, and decoupling classes through dependency injection. A practical example showing how to use polymorphism and dependency injection to reduce coupling in a bank account application.

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

Inheritance error debugging tips: Ensure correct inheritance relationships. Use the debugger to step through the code and examine variable values. Make sure to use the virtual modifier correctly. Examine the inheritance diamond problem caused by hidden inheritance. Check for unimplemented pure virtual functions in abstract classes.

Introduction to the method of obtaining HTTP status code in JavaScript: In front-end development, we often need to deal with the interaction with the back-end interface, and HTTP status code is a very important part of it. Understanding and obtaining HTTP status codes helps us better handle the data returned by the interface. This article will introduce how to use JavaScript to obtain HTTP status codes and provide specific code examples. 1. What is HTTP status code? HTTP status code means that when the browser initiates a request to the server, the service

C++ function inheritance should not be used in the following situations: When a derived class requires a different implementation, a new function with a different implementation should be created. When a derived class does not require a function, it should be declared as an empty class or use private, unimplemented base class member functions to disable function inheritance. When functions do not require inheritance, other mechanisms (such as templates) should be used to achieve code reuse.

Detailed explanation of C++ function inheritance: Master the relationship between "is-a" and "has-a" What is function inheritance? Function inheritance is a technique in C++ that associates methods defined in a derived class with methods defined in a base class. It allows derived classes to access and override methods of the base class, thereby extending the functionality of the base class. "is-a" and "has-a" relationships In function inheritance, the "is-a" relationship means that the derived class is a subtype of the base class, that is, the derived class "inherits" the characteristics and behavior of the base class. The "has-a" relationship means that the derived class contains a reference or pointer to the base class object, that is, the derived class "owns" the base class object. SyntaxThe following is the syntax for how to implement function inheritance: classDerivedClass:pu

What is object-oriented programming? Object-oriented programming (OOP) is a programming paradigm that abstracts real-world entities into classes and uses objects to represent these entities. Classes define the properties and behavior of objects, and objects instantiate classes. The main advantage of OOP is that it makes code easier to understand, maintain and reuse. Basic Concepts of OOP The main concepts of OOP include classes, objects, properties and methods. A class is the blueprint of an object, which defines its properties and behavior. An object is an instance of a class and has all the properties and behaviors of the class. Properties are characteristics of an object that can store data. Methods are functions of an object that can operate on the object's data. Advantages of OOP The main advantages of OOP include: Reusability: OOP can make the code more
