Javascript继承1:子类的的原型对象----类式继承

Posted 九转功成

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Javascript继承1:子类的的原型对象----类式继承相关的知识,希望对你有一定的参考价值。

//声明父类
function Parent(){
    this.parentValue = true;
    this.favorites = [‘看书‘]
}
//为父类添加公有方法
Parent.prototype.getParentValue = function(){
    return this.parentValue;
}
//声明子类
function Child(){
    this.childValue = false;
}
// 继承父类
Child.prototype =  new Parent()
//为子类添加方法
Child.prototype.getChildValue = function(){
    return this.childValue;
}

var instance = new Child()
console.log(instance.getParentValue())  //true
console.log(instance.getChildValue())   //false
/*
*注:使用instanceof检测某个对象是否是某个某个类的实例,
*    或者说某个对象是否继承了某个类
*/
console.log(instance instanceof Parent) //true
console.log(instance instanceof Child)  //true
console.log(Child instanceof Parent)    //false 为何?Child的原型继承了父类

console.log(Child.prototype instanceof Parent) //true
/*
*缺点:一个子类改变继承于父类的公有属性,其他子类会受到影响
*    如何避免??下一小节
*/
var child1 = new Parent()
var child2 = new Parent()
console.log(child2.favorites) //[‘看书‘]
child1.favorites.push(‘旅游‘)
console.lof(child2.favorites) //[‘看书‘,‘旅游‘]

设计模式中的经典笔录

以上是关于Javascript继承1:子类的的原型对象----类式继承的主要内容,如果未能解决你的问题,请参考以下文章

javascript原型继承

Javascript 对象 基于原型的继承

javascript 的继承

ECMAScript面向对象——之继承

js里面的对象继承几种方法

JavaScript面向对象