For security reasons, local classes and host classes cannot be inherited, but others can be inherited. ECMAScript does not strictly define abstract classes, but there are some classes that are not allowed to be used. The subclass will inherit all properties and methods of the superclass, including constructors and method implementations. Remember, all properties and methods are public, so subclasses can access these methods directly. Subclasses can also add new properties and methods that are not found in the superclass, and can also override properties and methods of the superclass.
The inheritance mechanism in JavaScript is not explicitly specified, but is implemented through imitation. This means that not all inheritance details are entirely handled by the interpreter.
Object impersonation
To put it bluntly, it is to first write a constructor method of super class A. Write another constructor of class B;
Then reference the constructor of A in B’s method;
Delete the reference to ClassA after use.
Define subclass attributes (all new subclass attributes are defined after deleting the reference)
<span style="font-size: 14px;">// 超类ClassA的构造方法function ClassA(sColor) {<br/> this.color = sColor; this.sayColor = function () {、<br/> alert(this.color);<br/> };<br/>}// 子类ClassB的构造方法function ClassB(sColor, sName) {<br/> // 引用ClassA的构造方法<br/> this.newMethod = ClassA; // 使用ClassA的构造方法够照ClassB<br/> this.newMethod(sColor); // 删除对ClassA的引用<br/> delete this.newMethod; /* 所有的子类新属性在删除引用后定义 */<br/> // 子类属性<br/> this.name = sName; this.sayName = function () {<br/> alert(this.name);<br/> };<br/>}</span>
Object impersonation can achieve multiple inheritance
A class can inherit multiple superclasses.
ClassX and ClassY, ClassZ wants to inherit these two classes.
If there are two classes ClassX and ClassY with properties or methods with the same name, ClassY has high priority.
Because it inherits from the later class.
<span style="font-size: 14px;">function ClassZ() {<br/> // 继承ClassX<br/> this.newMethod = ClassX; this.newMethod(); delete this.newMethod; //继承ClassY<br/> this.newMethod = ClassY; this.newMethod(); delete this.newMethod;<br/>}</span>
call() method
The call() method is most similar to the classic object impersonation method.
One parameter is used as the object of this. All other parameters are passed directly to the function itself.
<span style="font-size: 14px;">function ClassB(sColor, sName) {<br/> /*<br/> 将classB付给ClassA中的this<br/> 这时classA中的this实际指向是ClassB<br/> */<br/> ClassA.call(this, sColor); this.name = sName; this.sayName = function () {<br/> alert(this.name);<br/> };<br/>}</span>
apply() method
Two parameters, the object used as this and the array of parameters to be passed to the function .
The second parameter of apply can only be an array
<span style="font-size: 14px;">function ClassB(sColor, sName) {<br/> // 引用ClassA构造方法<br/> ClassA.apply(this, new Array(sColor)); // 也可以使用arguments<br/> // 只有超类中的参数顺序与子类中的参数顺序完全一致时才可以传递参数对象<br/> // ClassA.apply(this, arguments);<br/> // ClassB 自己的属性<br/> this.name = sName; this.sayName = function () {<br/> alert(this.name);<br/> };<br/>}</span>
Prototype chaining
Inherit this form Originally used for prototype chains in ECMAScript.
<span style="font-size: 14px;">// ClassA的构造方法function ClassA() {<br/> //要求为空,全部写在prototype上}// ClassA的属性ClassA.prototype.color = "blue";<br/>ClassA.prototype.sayColor = function () {<br/> alert(this.color);<br/>};// ClassB的构造方法function ClassB() {}// 继承ClassA的属性ClassB.prototype = new ClassA();// ClassB自己的属性,需要出现在继承之后ClassB.prototype.name = "";<br/>ClassB.prototype.sayName = function () {<br/> alert(this.name);<br/>};</span>
About the instanceof operation
In the prototype chain, the instanceof operator also operates in a unique way. instanceof returns true for both ClassA and ClassB for all instances of ClassB.
<span style="font-size: 14px;">var objB = new ClassB();<br/>alert(objB instanceof ClassA); //输出 "true"alert(objB instanceof ClassB); //输出 "true"</span>
Mixed method
<span style="font-size: 14px;">// ClassA的构造方法,只写属性,不写函数function ClassA(sColor) {<br/> this.color = sColor;<br/>}// 使用原型给ClassA赋予函数ClassA.prototype.sayColor = function () {<br/> alert(this.color);<br/>};// ClassB的构造方法function ClassB(sColor, sName) {<br/> // 先调用ClassA,继承ClassA的属性<br/> ClassA.call(this, sColor); this.name = sName;<br/>}// 再通过原型链继承ClassA的函数ClassB.prototype = new ClassA();// 通过原型链定义自己的函数ClassB.prototype.sayName = function () {<br/> alert(this.name);<br/>};</span>
In the ClassB constructor, use the object to pretend to inherit the sColor of the ClassA class Attributes.
#In the second highlighted line of code, use the prototype chain to inherit the methods of the ClassA class.
JavaScript Basics Strengthening Notes - Inheritance
For security reasons, local classes and host classes cannot inherit, others All can be inherited.
ECMAScript does not strictly define abstract classes, but there are some classes that are not allowed to be used.
The subclass will inherit all properties and methods of the superclass, including the implementation of constructors and methods. Remember, all properties and methods are public, so subclasses can access these methods directly. Subclasses can also add new properties and methods that are not found in the superclass, and can also override properties and methods of the superclass.
The inheritance mechanism in JavaScript is not explicitly specified, but is implemented through imitation. This means that not all inheritance details are entirely handled by the interpreter.
Object impersonation
To put it bluntly, it is to first write a constructor method of super class A. Write another constructor of class B;
Then reference the constructor of A in B’s method;
Delete the reference to ClassA after use.
Define subclass attributes (all new subclass attributes are defined after deleting the reference)
<span style="font-size: 14px;">// 超类ClassA的构造方法function ClassA(sColor) {<br/> this.color = sColor; this.sayColor = function () {、<br/> alert(this.color);<br/> };<br/>}// 子类ClassB的构造方法function ClassB(sColor, sName) {<br/> // 引用ClassA的构造方法<br/> this.newMethod = ClassA; // 使用ClassA的构造方法够照ClassB<br/> this.newMethod(sColor); // 删除对ClassA的引用<br/> delete this.newMethod; /* 所有的子类新属性在删除引用后定义 */<br/> // 子类属性<br/> this.name = sName; this.sayName = function () {<br/> alert(this.name);<br/> };<br/>}</span>
Object impersonation can achieve multiple inheritance
A class can inherit multiple superclasses.
ClassX and ClassY, ClassZ wants to inherit these two classes.
If there are two classes ClassX and ClassY with properties or methods with the same name, ClassY has high priority.
Because it inherits from the later class.
<span style="font-size: 14px;">function ClassZ() {<br/> // 继承ClassX<br/> this.newMethod = ClassX; this.newMethod(); delete this.newMethod; //继承ClassY<br/> this.newMethod = ClassY; this.newMethod(); delete this.newMethod;<br/>}</span>
call()方法
call() 方法是与经典的对象冒充方法最相似。
一个参数用作 this 的对象。其他参数都直接传递给函数自身。
<span style="font-size: 14px;">function ClassB(sColor, sName) {<br/> /*<br/> 将classB付给ClassA中的this<br/> 这时classA中的this实际指向是ClassB<br/> */<br/> ClassA.call(this, sColor); this.name = sName; this.sayName = function () {<br/> alert(this.name);<br/> };<br/>}</span>
apply() 方法
两个参数,用作 this 的对象和要传递给函数的参数的数组。
apply第二个参数只能是数组
<span style="font-size: 14px;">function ClassB(sColor, sName) {<br> // 引用ClassA构造方法<br> ClassA.apply(this, new Array(sColor)); // 也可以使用arguments<br> // 只有超类中的参数顺序与子类中的参数顺序完全一致时才可以传递参数对象<br> // ClassA.apply(this, arguments);<br> // ClassB 自己的属性<br> this.name = sName; this.sayName = function () {<br> alert(this.name);<br> };<br>}</span>
原型链(prototype chaining)
继承这种形式在 ECMAScript 中原本是用于 原型链 的。
<span style="font-size: 14px;">// ClassA的构造方法function ClassA() {<br> //要求为空,全部写在prototype上}// ClassA的属性ClassA.prototype.color = "blue";<br>ClassA.prototype.sayColor = function () {<br> alert(this.color);<br>};// ClassB的构造方法function ClassB() {}// 继承ClassA的属性ClassB.prototype = new ClassA();// ClassB自己的属性,需要出现在继承之后ClassB.prototype.name = "";<br>ClassB.prototype.sayName = function () {<br> alert(this.name);<br>};</span>
关于 instanceof 运算
在原型链中,instanceof 运算符的运行方式也很独特。对 ClassB 的所有实例,instanceof 为 ClassA 和 ClassB 都返回 true。
<span style="font-size: 14px;">var objB = new ClassB();<br/>alert(objB instanceof ClassA); //输出 "true"alert(objB instanceof ClassB); //输出 "true"</span>
混合方式
<span style="font-size: 14px;">// ClassA的构造方法,只写属性,不写函数function ClassA(sColor) {<br/> this.color = sColor;<br/>}// 使用原型给ClassA赋予函数ClassA.prototype.sayColor = function () {<br/> alert(this.color);<br/>};// ClassB的构造方法function ClassB(sColor, sName) {<br/> // 先调用ClassA,继承ClassA的属性<br/> ClassA.call(this, sColor); this.name = sName;<br/>}// 再通过原型链继承ClassA的函数ClassB.prototype = new ClassA();// 通过原型链定义自己的函数ClassB.prototype.sayName = function () {<br/> alert(this.name);<br/>};</span>
ClassB 构造函数中,用对象冒充继承 ClassA 类的 sColor 属性。
-
在第二行突出显示的代码中,用原型链继承 ClassA 类的方法。
相关推荐:
JavaScript继承之原型式继承、寄生式继承、寄生组合式继承用法实例详解
The above is the detailed content of JavaScript inheritance basics strengthening note sharing. For more information, please follow other related articles on the PHP Chinese website!

The main uses of JavaScript in web development include client interaction, form verification and asynchronous communication. 1) Dynamic content update and user interaction through DOM operations; 2) Client verification is carried out before the user submits data to improve the user experience; 3) Refreshless communication with the server is achieved through AJAX technology.

Understanding how JavaScript engine works internally is important to developers because it helps write more efficient code and understand performance bottlenecks and optimization strategies. 1) The engine's workflow includes three stages: parsing, compiling and execution; 2) During the execution process, the engine will perform dynamic optimization, such as inline cache and hidden classes; 3) Best practices include avoiding global variables, optimizing loops, using const and lets, and avoiding excessive use of closures.

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

The shift from C/C to JavaScript requires adapting to dynamic typing, garbage collection and asynchronous programming. 1) C/C is a statically typed language that requires manual memory management, while JavaScript is dynamically typed and garbage collection is automatically processed. 2) C/C needs to be compiled into machine code, while JavaScript is an interpreted language. 3) JavaScript introduces concepts such as closures, prototype chains and Promise, which enhances flexibility and asynchronous programming capabilities.

Different JavaScript engines have different effects when parsing and executing JavaScript code, because the implementation principles and optimization strategies of each engine differ. 1. Lexical analysis: convert source code into lexical unit. 2. Grammar analysis: Generate an abstract syntax tree. 3. Optimization and compilation: Generate machine code through the JIT compiler. 4. Execute: Run the machine code. V8 engine optimizes through instant compilation and hidden class, SpiderMonkey uses a type inference system, resulting in different performance performance on the same code.

JavaScript's applications in the real world include server-side programming, mobile application development and Internet of Things control: 1. Server-side programming is realized through Node.js, suitable for high concurrent request processing. 2. Mobile application development is carried out through ReactNative and supports cross-platform deployment. 3. Used for IoT device control through Johnny-Five library, suitable for hardware interaction.

I built a functional multi-tenant SaaS application (an EdTech app) with your everyday tech tool and you can do the same. First, what’s a multi-tenant SaaS application? Multi-tenant SaaS applications let you serve multiple customers from a sing


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

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

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