>웹 프론트엔드 >JS 튜토리얼 >JS의 상속 방법은 무엇입니까?

JS의 상속 방법은 무엇입니까?

零下一度
零下一度원래의
2017-06-28 09:57:391054검색

1. 프로토타입 체인 상속

Child.prototype = new Parent();

 1 function Parent (name, age) { 2     this.name = name; 3     this.age = age; 4 } 5 Parent.prototype.say = function(){ 6     console.log('hello, my name is ' + this.name); 7 }; 8 function Child() { 9 }10 Child.prototype = new Parent('pursue');11 var child1 = new Child();12 child1.say(); //hello, my name is pursue13 var child2 = new Child();14 console.log(child1.say === child2.say);//true15 console.log(child1.name === child2.name);//true

2.call(thisObj, param1, param2,...)

 1 function Parent(username){ 2     this.username = username; 3     this.hello = function(){ 4       alert(this.username); 5     } 6   } 7   function Child(username,password){ 8     Parent.call(this,username); 9     this.password = password;10     this.world = function(){11       alert(this.password);12     }13   }14   var parent = new Parent("zhangsan");15   var child = new Child("lisi","123456");16   parent.hello();17   child.hello();18   child.world();

3. param1, param2,...])

 1 function Parent(username){ 2     this.username = username; 3     this.hello = function(){ 4       alert(this.username); 5     } 6   } 7   function Child(username,password){ 8     Parent.apply(this,new Array(username)); 9     this.password = password;10     this.world = function(){11       alert(this.password);12     }13   }14   var parent = new Parent("zhangsan");15   var child = new Child("lisi","123456");16   parent.hello();17   child.hello();18   child.world();

4. 조합 상속(호출+프로토타입 체인/적용+프로토타입 체인)

 1 function Parent(hello){ 2     this.hello = hello; 3   } 4   Parent.prototype.sayHello = function(){ 5     alert(this.hello); 6   } 7   function Child(hello,world){ 8     Parent.call(this,hello);//利用 call 方法 将父类的属性继承过来 9     //Parent.apply(this,new Array(hello));//利用 apply 方法 将父类的属性继承过来10     this.world = world;//新增一些属性11   }12   Child.prototype = new Parent();//将父类的方法继承过来13   Child.prototype.sayWorld = function(){//新增一些方法14     alert(this.world);15   }16   var c = new Child("zhangsan","lisi");17   c.sayHello();18   c.sayWorld();

5. 기생 조합 상속은 4와 유사합니다. 프로토타입 체인이 Object.create(Parent.prototype)

 1 function Parent(hello){ 2     this.hello = hello; 3   } 4   Parent.prototype.sayHello = function(){ 5     alert(this.hello); 6   } 7   function Child(hello,world){ 8     Parent.call(this,hello);//利用 call 方法 将父类的属性继承过来 9     //Parent.apply(this,new Array(hello));//利用 apply 方法 将父类的属性继承过来10     this.world = world;//新增一些属性11   }12   Child.prototype = Object.create(Parent.prototype);//将父类的方法继承过来13   Child.prototype.sayWorld = function(){//新增一些方法14     alert(this.world);15   }16   var c = new Child("zhangsan","lisi");17   c.sayHello();18   c.sayWorld();

로 변경되었습니다.

위 내용은 JS의 상속 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.