zoukankan      html  css  js  c++  java
  • JavaScript继承

    1、类式继承

    //使subclass继承superclass

    function extend(subclass, superclass){
        function F() {};
        F.prototype = superclass.prototype;
        subclass.prototype = new F();//类式继承
        subclass.prototype.constructor = subclass;
        
        subclass.superclass = superclass.prototype;
        if (superclass.prototype.constructor == Object.prototype.constructor){
            superclass.prototype.constructor = superclass;
        }
    }

    2、原型式继承

    function clone(object) {

        function F() {};

        F.prototype = object.prototype;//原型继承

        return new F();

     }

    3、掺元类

    //用givingclass类来扩充receivingclass类

    function augment(receivingclass, givingclass) {

        if (arguments[2]) {

            for (var i = 2, len = arguments.length; i < len; i += 1) {

                receivingclass.prototype[arguments[i]] = givingclass.prototype[arguments[i]];

            }  

        } else {

            for (methodName in givingclass.prototype) {

                if (!receivingclass.prototype[methodName]) {

                    receivingclass.prototype[methodName] = givingclass.prototype[methodName];

                }

             }

        }

    }

    function extend(subclass, superclass){
    function F() {};
    F.prototype = superclass.prototype;
    subclass.prototype = new F();
    subclass.prototype.constructor = subclass;


    subclass.superclass = superclass.prototype;
    if (superclass.prototype.constructor == Object.prototype.constructor){
    superclass.prototype.constructor = superclass;
    }
    }function extend(subclass, superclass){
    function F() {};
    F.prototype = superclass.prototype;
    subclass.prototype = new F();
    subclass.prototype.constructor = subclass;


    subclass.superclass = superclass.prototype;
    if (superclass.prototype.constructor == Object.prototype.constructor){
    superclass.prototype.constructor = superclass;
    }
    }
    function extend(subclass, superclass){
    function F() {};
    F.prototype = superclass.prototype;
    subclass.prototype = new F();
    subclass.prototype.constructor = subclass;


    subclass.superclass = superclass.prototype;
    if (superclass.prototype.constructor == Object.prototype.constructor){
    superclass.prototype.constructor = superclass;
    }
    }
    function extend(subclass, superclass){
    function F() {};
    F.prototype = superclass.prototype;
    subclass.prototype = new F();
    subclass.prototype.constructor = subclass;


    subclass.superclass = superclass.prototype;
    if (superclass.prototype.constructor == Object.prototype.constructor){
    superclass.prototype.constructor = superclass;
    }
    }
  • 相关阅读:
    PTA习题解析——修理牧场(2 种解法)
    MySQL——维护和用户管理
    MySQL 5+ 特性
    MySQL——增、删、改
    数字时代云计算与边缘计算的区别
    5G对工业互联网应用的影响
    物联网新商业四大趋势
    变革之下,“大数据安全”成数字化转型“必答题”
    Serverless 的初心、现状和未来
    7 个建议让 Code Review 高效又高质
  • 原文地址:https://www.cnblogs.com/wuzy/p/2993719.html
Copyright © 2011-2022 走看看