zoukankan      html  css  js  c++  java
  • JavaScript设计模式学习之路——继承

    早在学习java的时候,就已经接触了继承,在java中因为有extends关键字,因此继承就比较简单。但是在JavaScript中,只能通过灵活的办法实现类的继承。

    下面是我昨天在学习过程中,了解到的实现继承的一些方法,包括有具体的代码以及该方法的优缺点:

    1.组合继承方式

      原理:在子类的构造函数中,调用父类的构造函数,在子类原型上实例化父类,所以称为组合模式。

      优点:融合了类式继承和构造函数继承的优点

      缺点:父类构造函数调用了两次。第一次是使用构造函数时调用了父类的构造函数,第二次是实现子类原型的类式继承时又调用了一次。

      

        /*
        1.组合继承方式
            缺点:在初始化时会调用两次构造函数
        */
        var SuperClass = function(id,name){
            this.id = id;
            this.name = name;
            this.books = ['javascript','html','css'];
    
        }
        SuperClass.prototype.getName = function(){
            return this.name;
    
        }
        SuperClass.prototype.getId = function(){
            return this.id;
    
        }
        var SubClass = function(id,name,price){
            SuperClass.call(this,id,name);
            this.price = price;
    
        }
        SubClass.prototype = new SuperClass();
        SubClass.prototype.getPrice = function(){
            return this.price;
    
        }
    
        //测试用例
        var sub = new SubClass('001','css',25);
        sub.books.push('internet');
        console.log(sub.books);//["javascript", "html", "css", "internet"]
        var father = new SuperClass('002','html');
        console.log(father.books);// ["javascript", "html", "css"]

    2、寄生式组合继承

      原理:原型继承和构造函数继承组合,此方法是Douglas Crockford对寄生式继承的一个改造。

        /**
         *2.寄生式组合继承法
        **/
        function inheritObject(o){
            function F(){};
            F.prototype = o;
            return new F();
        }
        /**
         *1、继承设置
         *传递参数:subclass子类
         *传递参数:superclass父类
        **/
        function inheritPrototype(subClass,superClass){
            //先将父类原型副本保持一份在变量中
            var p = inheritObject(superClass.prototype);
            p.constructor = subClass;
            subClass.prototype = p;
    
        }
    
        var SuperClass = function(id,name){
            this.id = id;
            this.name = name;
            this.books = ['javascript','html','css'];
    
        }
        SuperClass.prototype.getName = function(){
            return this.name;
    
        }
        SuperClass.prototype.getId = function(){
            return this.id;
    
        }
        var SubClass = function(id,name,price){
            SuperClass.call(this,id,name);
            this.price = price;
    
        }
        inheritPrototype(SubClass,SuperClass);
        SubClass.prototype.getPrice = function(){
            return this.price;
    
        }
    
    
        //测试用例
        var sub = new SubClass('001','css',25);
        sub.books.push('internet');
        console.log(sub.books);//["javascript", "html", "css", "internet"]
        var father = new SuperClass('002','html');
        console.log(father.books);// ["javascript", "html", "css"]
        console.log(SubClass.prototype instanceof SuperClass);//SubClass的实例才是SuperClass的一个实例,true

    3、多重继承

      原理:将所有的目标属性和方法复制,可带多个参数。

        Object.prototype.mix = function(){
            //复制属性和方法        
            var len = arguments.length;
    
            for(var i = 0; i < len; i++){
                var arg = arguments[i];
                for(var property in arg){
                    this[property] = arg[property];
                }
            }
    
        }
        var Book = function(id,name){
            this.id = id;
            this.name = name;
    
        }
        var Image = function(url,size){
            this.url = url;
            this.size = size;
        }
        //测试用例
        var book = new Book('001','javascript');
        var image = new Image('http://baidu.com',52);
        var imageBook = new Object();
        var imageBook1 = new Object();
        imageBook.mix(book,image);
        imageBook1.mix(book,image);
        imageBook1.name = "真的很不错";
        console.log(imageBook);// Object { id="001",  name="javascript",  url="http://baidu.com",  更多...}
        console.log(imageBook1);// Object { id="001",  name="真的很不错",  url="http://baidu.com",  更多...}

    4、多态

      原理:非常类似于java中的函数的重载,只不过加上了一些封装

      例子:比如一个add()方法,无参数,返回0;一个参数,返回参数本身值+10;两个参数,返回两个参数值相加

      

        //多态
        var add = function(){
            function zero(){
                return 0;
            }
            function one(num){
                return 10 + num;
            }
            function two(num1,num2){
                return num1 + num2;
            }
            var arg = arguments;
            var len = arg.length;
            switch(len){
                case 0 : return zero();
                case 1 : return one(arg[0]); 
                case 2 : return two(arg[0],arg[1]); 
            }
        }
        console.log(add());//0
        console.log(add(5));//15
        console.log(add(2,18));//20

    到此,第二章的知识也就完毕了,迎来第三章。有错误的话,请大家留言指正哦~~

  • 相关阅读:
    spring管理hibernate,mybatis,一级缓存失效原因
    The constructor ClassPathXmlApplicationContext(String) refers to the missing type BeansException
    idea中Hibernate错误:无法解析表
    使用Dom4解析xml
    关于idea中新建web项目 webapp文件夹没有小蓝点 ,启动服务,访问不到解决方案
    解决VS编译太慢问题
    Entity FrameWork6 Code First带virtual关键字外键 Asp.Net WebApi无法返回实体类数据问题
    webapi请求返回{"$id":"1","Message":"请求的资源不支持 http 方法“GET”。"}
    WPF的BusyIndicator控件只显示遮罩层,不显示提示层问题
    [转]Mysql将数据分组后取出时间最近的数据
  • 原文地址:https://www.cnblogs.com/tiffanybear/p/5695036.html
Copyright © 2011-2022 走看看