javascript prototype原型继承

本文详细介绍了JavaScript中实现继承的七种方法,包括构造函数绑定、prototype模式、直接继承prototype等,并提供了具体示例。

javascript中的每个对象都有prototype属性,Javascript中对象的prototype属性的解释是:返回对象类型原型的引用。

A.prototype = new B();

理解prototype不应把它和继承混淆。A的prototype为B的一个实例,可以理解A将B中的方法和属性全部克隆了一遍。A能使用B的方法和属性。这里强调的是克隆而不是继承。可以出现这种情况:A的prototype是B的实例,同时B的prototype也是A的实例。


1.如何继承

//动物

functionAnimal(){

 this.species = "动物";

}

//

functionCat(name, color){

 this.name = name;

 this.color = color;

}

2.方法一:构造函数绑定

父对象的构造函数绑定在子对象
functionCat(name, color){

  Animal.apply(this, arguments);//在当前对象中调用函数Annimal

        //Animal.apply(this,[name, color]);

    //apply()方法的第二个参数为数组或arguments参数集合

       //Animal.call(this, name, color);(推荐)

       //call()方法的第二个及后面可以是任意多个参数


 this.name = name;

 this.color = color;           

     }

var cat1 = new Cat("大毛","黄色");

alert(cat1.species); //动物


3.方法二:prototype模式
 
        //Catprototype对象指向一个Animal的实例,相当于删除了prototype对象原先的值,再赋予新值

Cat.prototype = new Animal();

       //任何prototype对象都有一个constructor属性其构造函数,即,   

       //没有上一行,Cat.prototype.constructor是指向Cat的;

       //加了上一行,Cat.prototype.constructor指向Animal

       //下一行,是将constructor指回原对象构造函数。

       Cat.prototype.constructor = Cat;

        var   cat1 = new Cat("大毛","黄色");

       alert(cat1.species); //动物

4.方法三:直接继承prototype

由于Animal对象中,不变的属性都可以直接写入Animal.prototype。可以让Cat()跳过Animal(),直接继Animal.prototype

function Animal(){ 

        }

        Animal.prototype.species= "动物";

        Cat.prototype =Animal.prototype;

        Cat.prototype.constructor = Cat;

        var cat1 = new Cat("大毛","黄色");

alert(cat1.species); //动物

//存在问题:红色一行,把Animal.prototype对象的constructor属性也改掉了

5.方法四:利用空对象作为中介

var F = function(){};

F.prototype =Animal.prototype;

Cat.prototype = new F();

Cat.prototype.constructor = Cat;

F是空对象,所以几乎不占内存。这时,修改Catprototype对象,就不会影响到Animalprototype对象。

6.方法五:拷贝继承
把父对象的所有属性和方法,拷贝到子对象

function extend2(Child, Parent) {

var p =Parent.prototype;

var c =Child.prototype;

for (var  i in p) {

c[i] = p[i];

}

c.uber = p;//为了方便在子类中知道它的父类,

  uber是一个变量


7.方法六:非构造函数继承

var Chinese = {
nation:'中国'
};
var Doctor ={
career:'医生'
}
以上对象没有构造函数,如何让医生去继承中国人,也就是说,怎样才能生成一个中国医生的对象?

json格式发明人DouglasCrockford提倡的object()函数:

  function object(o) { //o为父类,传递进来

  functionF() {}

  F.prototype = o;

  return new F();

   }

第一步先在父对象的基础上生成子对象

var Doctor = object(Chinese);

再加上子对象本身的属性

Doctor.career = '医生';



8.方法七:深拷贝

 function  deepCopy(p, c) {

    varc = c || {};

    for (var i in p) {

      if (typeof p[i] === 'object') {

        c[i] = (p[i].constructor === Array) ? [] : {};

        deepCopy(p[i], c[i]);

      } else {

         c[i] = p[i];

      }
    }

    return c;
 }

例如:var Doctor = deepCopy(Chinese);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值