zoukankan      html  css  js  c++  java
  • 几种常见的继承

    原文地址:http://blog.csdn.net/caoyafeicyf/article/details/53354112  

    嘎嘎

    常见的继承有扩展原型对象实现继承、替换原型对象实现继承、混入继承、混入+原型继承、经典继承、借用构造函数实现继承这六种。每个人的叫法可能不同,但是原理都一样。

    扩展原型对象实现继承

    实现原理:函数有一个prototype的属性(原型对象),通过给这个原型对象添加一个属性、方法,从而可以让构造函数的实例可以访问到

    function Person(){}
    Person.prototype.name="Jim";
    Person.prototype.sayHello=function () {
        console.log("Hello");  
    }
    
    var p1=new Person();
    console.log(p1.name) //输出"Jim"
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    替换原型对象实现继承

    上面这种方式是最简单的也是最好理解的,但是有缺点,设置少数的属性或者方法还可以,但是要是设置多个呢?这种继承方法就不行了,太麻烦了,于是有了这种继承方式:替换原型对象实现继承。用于多个属性、方法的实现。

    function Person () {}
    Person.prototype={
       constructor:Person,
       a1:function () {},
       a2:function () {},
       a3:function () {},
       a4:function () {},
       a5:function () {},
       .......
    }
    var p1=new Person();
    p1.a1();
    p1.a2();
    .......
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    注意:使用这种方式继承,必须要加上constructor:Person:Person这个属性,因为Person.prototype会将原型对象的这个属性替换掉,如果不加上,值将不指向构造函数。

    混入继承

    使用场景:已知对象o1,o3,需要将o1中的属性、方法拷贝到o3里面。

    var o1={name:"张三",age:18,height:180};
    var o2=function () {};
    o2.prototype.a="a";
    var o3=new o2();
    //功能封装
    function mixin(target,source) {
       for(var key in source) {
          target[key]=source[key];
       }
       return target;
    }
    
    mixin(o3,o1)//这样o3里面就有了o1的属性和方法了。
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    注意:jQuery里面的extend方法就是这个原理实现的。

    混入+原型继承

    利用混入继承向原型对象中添加属性和方法,其本质还是用了混入继承封装的方法

    function Person () {};
    Person.prototype.extend=function (source) {
       mixin(Person.prototype,source);
    }
    
    Person.prototype.extend({a:20,b:25,c:30});
    //其实就相当于Person.prototype.a=20;Person.prototype.b=25......
    
    var p1=new Person();
    //p1就可以直接访问p1.a;p1.b了。
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    注意:在jQ中,如果你想要在jQ上面添加方法,用的是$.fn.extend(),其实它就相当于jquery.prototype.extend()

    经典继承

    由道格拉斯提出。使用场景:已知一个对象o,需要创建一个新的对象,这个新的对象继承自对象o。

    //功能封装
    function create(o) {
        function F(){}
        F.prototype=o;
        return new F(); 
    }
    
    var o={name:"张三",age:18};
    var o2=create(o);//这样o2就继承自o了
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    借用构造函数实现继承

    使用场景:子类构造函数借用父类构造函数来完成,给子类的实例添加属性。

    function f1(name,age){
       this.name=name;
       this.age=age;
    }
    
    function f2(name,age,length) {
        f1.call(this,name,age)
        this.length=length;
    }
    
    var ff2=new f2("张三",23,180);
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    总结:这几种方法原理虽然不难,但是难的是如何灵活运用,这个也没办法,只能自己实践。

     
    1
  • 相关阅读:
    MySQL GTID复制Slave跳过错误事务Id以及复制排错问题总结
    Git基础命令整理
    原创-公司项目部署交付环境预检查shell脚本
    解决SecureCRT超时自动断开的问题
    Linux设置显示中文和设置字体
    高等代数4 线性方程组
    高等代数3 行列式
    高等代数2 向量组
    高等代数1 矩阵
    离散数学4 组合数学
  • 原文地址:https://www.cnblogs.com/gs97/p/7472919.html
Copyright © 2011-2022 走看看