inherit 1. What is inheritanceInheritance: First of all, inheritance is a relationship, the relationship between classes. There are no classes in JS, but classes can be simulated through constructors, and then inheritance can be achieved through prototypes.
We can think of the prototype, and its two functions are:
Inheritance is a relationship: the relationship between the parent class level and the class level example: Person categories: name, gender, age, eating, sleeping Student categories: name, gender, age, eating, sleeping, and studying behaviors Teacher category: name, gender, age, meals, sleep, salary, teaching behavior Programmer: Name, Gender, Age, Eating, Sleeping, Salary, Writing Code Driver category: name, gender, age, meals, sleep, salary, driving Animal categories: weight, color, eating Dog categories: weight, color, eating, biting Erha category: weight, color, eating, biting to make the owner happy, woof woof, you are so handsome Object-oriented features: encapsulation, inheritance, polymorphism
2. Three methods of JavaScript inheritanceConstructor property inheritance: borrowing constructors When inheriting, you don't need to change the prototype's pointer, you can just call the parent's constructor to assign values to the properties. —— Borrowing constructor: Take the constructor of the parent to be inherited and use it. Borrowing constructor:
Advantages: Solve the problem of attribute inheritance and non-duplicate values Defect: Methods in parent classes cannot be inherited function Person (name, age) { this.type = 'human' this.name = name this.age = age } function Student (name, age) { // Borrow the constructor to inherit the attribute member Person.call(this, name, age) } var s1 = Student('张三', 18) console.log(s1.type, s1.name, s1.age) // => human Zhang San 18 Examples: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> <script> function Person(name, age, sex, weight) { this.name = name; this.age = age; this.sex = sex; this.weight = weight; } Person.prototype.sayHi = function () { console.log("Hello"); }; function Student(name,age,sex,weight,score) { //Borrow the constructor Person.call(this,name,age,sex,weight); this.score = score; } var stu1 = new Student("Xiaoming",10,"male","10kg","100"); console.log(stu1.name, stu1.age, stu1.sex, stu1.weight, stu1.score); var stu2 = new Student("Xiaohong",20,"Female","20kg","120"); console.log(stu2.name, stu2.age, stu2.sex, stu2.weight, stu2.score); var stu3 = new Student("Xiao Li",30,"Yao","30kg","130"); console.log(stu3.name, stu3.age, stu3.sex, stu3.weight, stu3.score); </script> </head> <body> </body> </html> Prototype method inheritance of constructors: copy inheritance (for-in) Copy inheritance; copy the properties or methods of one object directly to another object function Person (name, age) { this.type = 'human' this.name = name this.age = age } Person.prototype.sayName = function () { console.log('hello ' + this.name) } function Student (name, age) { Person.call(this, name, age) } // The prototype object copies and inherits the prototype object members for(var key in Person.prototype) { Student.prototype[key] = Person.prototype[key] } var s1 = Student('张三', 18) s1.sayName() // => hello Zhang San Examples: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> <script> //Copy inheritance; copy the properties or methods of an object directly to another object function Person() { } Person.prototype.age=10; Person.prototype.sex="Male"; Person.prototype.height=100; Person.prototype.play = function () { console.log("having fun"); }; var obj2={}; //Person has a prototype in its construction. Prototype is an object. In it, age, sex, height, and play are all properties or methods of the object. for(var key in Person.prototype){ obj2[key]=Person.prototype[key]; } console.dir(obj2); obj2.play(); </script> </head> <body> </body> </html> Another way of inheritance: prototype inheritance Prototype inheritance: changing the prototype's direction function Person (name, age) { this.type = 'human' this.name = name this.age = age } Person.prototype.sayName = function () { console.log('hello ' + this.name) } function Student (name, age) { Person.call(this, name, age) } //Use the characteristics of prototype to achieve inheritance Student.prototype = new Person() var s1 = Student('张三', 18) console.log(s1.type) // => human s1.sayName() // => hello Zhang San Combination inheritance: prototype + borrowed constructor inheritance <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> <script> //Prototype inheritance //Borrowing constructor to implement inheritance //Combined inheritance: prototype inheritance + borrowing constructor inheritance function Person(name, age, sex) { this.name=name; this.age=age; this.sex=sex; } Person.prototype.sayHi = function () { console.log("Sawadee Ka"); }; function Student(name,age,sex,score) { //Borrowing constructor: Problem of duplicate attribute values Person.call(this,name,age,sex); this.score=score; } //Change the prototype pointing to ---- inheritance Student.prototype = new Person(); //Do not pass the value Student.prototype.eat = function () { console.log("eat"); }; var stu=new Student("小黑",20,"男","100分"); console.log(stu.name,stu.age,stu.sex,stu.score); stu.sayHi(); stu.eat(); var stu2=new Student("小黑黑",200,"男人","1010分"); console.log(stu2.name,stu2.age,stu2.sex,stu2.score); stu2.sayHi(); stu2.eat(); //Both properties and methods are inherited</script> </head> <body> </body> </html> Inheritance SummaryPrototype inheritance: changing the prototype's direction Borrowing constructor inheritance: mainly solves the problem of attributes Combined inheritance: prototype inheritance + borrowed constructor inheritance It can solve both attribute problems and method problems Copy inheritance: It is to copy the attributes or methods that need to be shared in an object to another object by directly traversing them. SummarizeThis concludes this article about the three methods of JavaScript inheritance. For more information about JavaScript inheritance methods, please search previous articles on 123WORDPRESS.COM or continue browsing the following related articles. I hope you will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: MySQL database operation and maintenance data recovery method
>>: Detailed explanation of the installation and use of Linux scheduled tasks crontabs
It has been a long time since the last update of ...
1. Installation 1. Download Go to the MySQL offic...
In the project, it is necessary to obtain the lat...
HTML is a hybrid language used for publishing on ...
Why doesn't your height:100% work? This knowl...
Table of contents 1. What is deconstruction? 2. A...
This article collects 20 excellent web page color ...
With the popularization of 3G, more and more peop...
This story starts with an unexpected discovery tod...
Ubuntu install jdk: [link] Install Eclipse on Ubu...
1. Introduction to DockerUI DockerUI is based on ...
The project scaffolding built with vue-cli has al...
Use scenarios: The jump path needs to be dynamica...
One time we talked about the dice rolling game. A...
This article shares the specific code of vue+elem...