Cet article partage principalement avec vous des exemples de 5 façons d'implémenter l'héritage en js, dans l'espoir de vous aider à mieux comprendre l'implémentation de l'héritage js.
1. La première méthode d'héritage : emprunt d'identité d'objet
| function Parent(username){ this.username = username; this.hello = function(){ alert(this.username); } } function Child(username,password){ Parent.apply(this,new Array(username)); this.password = password; this.world = function(){ alert(this.password); } } var parent = new Parent("zhangsan"); var child = new Child("lisi","123456"); parent.hello(); child.hello(); child.world(); Copier après la connexion Copier après la connexion |
<🎜>1<🎜 ><🎜>2<🎜><🎜>3 <🎜><🎜>4<🎜><🎜>5<🎜><🎜>6<🎜><🎜>7<🎜><🎜>8<🎜> <🎜>9<🎜><🎜>10< 🎜><🎜>11<🎜><🎜>12<🎜><🎜>13<🎜><🎜>14<🎜><🎜>15<🎜>< 🎜>16<🎜><🎜>17<🎜 ><🎜>18<🎜><🎜>19<🎜><🎜>20<🎜><🎜>21<🎜><🎜>22<🎜><🎜 >23<🎜><🎜>24<🎜> | function Person(){ } Person.prototype.hello = "hello"; Person.prototype.sayHello = function(){ alert(this.hello); } function Child(){ } Child.prototype = new Person();//这行的作用是:将Parent中将所有通过prototype追加的属性和方法都追加到Child,从而实现了继承 Child.prototype.world = "world"; Child.prototype.sayWorld = function(){ alert(this.world); } var c = new Child(); c.sayHello(); c.sayWorld(); Copier après la connexion Copier après la connexion | tr>
3、继承的第三种方式:apply()方法方式
apply方法接受2个参数,
A、第一个参数与call方法的第一个参数一样,即赋值给类(即方法)中出现的this
B、第二个参数为数组类型,这个数组中的每个元素依次赋值给类(即方法)所接受的参数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | function Parent(username){ this.username = username; this.hello = function(){ alert(this.username); } } function Child(username,password){ Parent.apply(this,new Array(username)); this.password = password; this.world = function(){ alert(this.password); } } var parent = new Parent("zhangsan"); var child = new Child("lisi","123456"); parent.hello(); child.hello(); child.world(); Copier après la connexion Copier après la connexion |
4、继承的第四种方式:原型链方式,即子类通过prototype将所有在父类中通过prototype追加的属性和方法都追加到Child,从而实现了继承
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | function Person(){ } Person.prototype.hello = "hello"; Person.prototype.sayHello = function(){ alert(this.hello); } function Child(){ } Child.prototype = new Person();//这行的作用是:将Parent中将所有通过prototype追加的属性和方法都追加到Child,从而实现了继承 Child.prototype.world = "world"; Child.prototype.sayWorld = function(){ alert(this.world); } var c = new Child(); c.sayHello(); c.sayWorld(); Copier après la connexion Copier après la connexion |
5、继承的第五种方式:混合方式
混合了call方式、原型链方式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | function Parent(hello){ this.hello = hello; } Parent.prototype.sayHello = function(){ alert(this.hello); } function Child(hello,world){ Parent.call(this,hello);//将父类的属性继承过来 this.world = world;//新增一些属性 } Child.prototype = new Parent();//将父类的方法继承过来 Child.prototype.sayWorld = function(){//新增一些方法 alert(this.world); } var c = new Child("zhangsan","lisi"); c.sayHello(); c.sayWorld(); Copier après la connexion |
希望本文所述对大家JavaScript程序设计有所帮助。
相关推荐:
学习javascript面向对象 javascript实现继承的方式_javascript技巧
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!