js面向对象设计

面向对象模式

<script>
    //1.工厂模式
    function product(id ,name , desc){
        var o = new Object();
        o.id = id;
        o.name = name;
        o.desc = desc;
        o.getname = function(){
            alert(this.name)
        }
        return o;
    }
    var product1 = product("1", '包子', "描述:小笼包");
    var product2 = product("2", '豆浆', "描述:豆浆");

    //2.构造函数模式 (大写字母开头)
    function User(name,mobile){
        this.name =  name;
        this.mobile = mobile;
        this.getname = function(){
            alert(this.name)
        }
    }

    var user1 = new User("Tom", "13000000000");
    var user2 = new User("John", "13333333333");

    alert(user1.constructor == User) //true

        /*
        1.没有显式创建对象
        2.直接将属性和方法赋给了this对象
        3.没有return语句
        * */

    /*
    * 创建新的实例 new
    * 1.创建了一个新的对象
    * 2.将构造函数的作用域赋给新对象(this就会指向新对象)
    * 3.执行构造函数中的代码(为新对象添加属性)
    * 4.返回新对象
    * */

    /**
     * 构造函数的问题:
     * 每个方法都要在实例上重新创建一遍,不同实例上的同名函数是不相等的。
     *
     * */
    alert(user1.getname == user2.getname )//false

    function User(name,mobile){
        this.name =  name;
        this.mobile = mobile;
        this.getname = getname;
    }
    function getname(){
        alert(this.name)
    }
    alert(user1.getname == user2.getname )//true
    /**
     * 把getname指向了全局作用域的getname函数,但是如果有很多方法就需要定义很多全局函数,这样就失去了封装性。
     */

    //3.原型模式
    /*
    * 每个函数都有一个prototype(原型)属性,这是一个指针指向一个对象,这个对象可以包含所有实例共享的属性和方法
    * */
    function Product(){

    }
    Product.prototype.name = "包子";
    Product.prototype.id = "123";
    Product.prototype.desc = "描述:小笼包";
    Product.prototype.getName = function(){
        alert(this.name)
    };

    var product1 = new Product();
    product1.getName(); //包子
    var product2 = new Product();
    alert(product1.getName == product2.getName)//true

    //实例重写原型的属性
    product1.name = '面包';
    console.log(product1.name)
    console.log(product2.name)
    delete(product1.name)
    console.log(product1.name)
    console.log(product2.name)

    //更简单的原型语法

    function Product(){

    }
    Product.prototype = {
            name : "套餐",
            id : "123",
            desc :  "描述:套餐",
            include: ['米饭', '菜'],
            getName : function(){
                alert(this.name)
            }
    }
    //此时constructor 属性就不再指向Product了,变成了Object
    /*
    * 原型模式的缺点,对于共享的引用类型,一个修改就会导致所有实例的修改
    * */

    var product1 = new Product();
    var product2 = new Product();
    console.log(product1.include)
    console.log(product2.include)
    product1.include.push('饮料');
    console.log(product1.include)
    console.log(product2.include)

    //4.组合使用构造函数模式和原型模式

    function User(name,mobile){
        this.name =  name;
        this.mobile = mobile;
        this.address = ['add1','add2']
    }
    User.prototype = {
        constructor: User,
        getName: function(){
            alert(this.name)
        }
    }
    var user1 = new User('Jack','13312345678');
    var user2 = new User('Tom','13011111111');
    console.log(user1.address)
    console.log(user2.address)
    user1.address.push("add3")
    console.log(user1.address)
    console.log(user2.address)

    //实例属性在构造函数中定义,而所有实例共享的属性和方法在原型中定义
</script>

继承

 <script>
//        1.原型继承
        function SuperType(){
            this.prototype = true;
            this.color = ['red','blue']
        }
        SuperType.prototype.getSuperValue = function(){
            return this.prototype;
        }

        function SubType(){
            this.subpropertype = false;
        }
        //继承
        SubType.prototype = new SuperType();
        SubType.prototype.getSubValue = function(){
            return this.subpropertype;
        }

        var instance = new SubType();
        alert(instance.getSuperValue());//true

        //原型继承的问题   包含引用类型的原型
        var instance1 = new SubType();
        instance1.color.push("green");
        console.log(instance1.color)
        var instance2 = new SubType();
        console.log(instance2.color)

        //2.借用构造函数
        //好处:可以传递参数

        function SuperType(id,name){
            this.color = ['red','blue'];
            this.id = id;
            this.name = name;
        }
        function SubType(){
            //继承 SuperType
            SuperType.call(this,'11','name')
        }
        var instance1 = new SubType();
        instance1.color.push("green");
        console.log(instance1.color)
        var instance2 = new SubType();
        console.log(instance2.color)
        console.log(instance2.id)
        console.log(instance2.name)

        //call apply 实际上是在未来将要新创建的SubType实例环境下调用了SuperType构造函数。这样每个实例上就有自己的属性副本

        //3.组合继承 原型链和借用构造函数组合
        function SuperType(name){
            this.color = ['red','blue'];
            this.name = name;
        }
        SuperType.prototype.sayName = function(){
            console.log(this.name)
        }
        function SubType(name,id){
            //继承 SuperType 属性
            SuperType.call(this,name);
            this.id = id;
        }
        //继承方法
        SubType.prototype = new SuperType();
        SubType.prototype.sayId = function(){
            console.log(this.id)
        }

        var instance1 = new SubType('instance1',1);
        instance1.color.push("green");
        console.log(instance1.color)
        instance1.sayName();
        instance1.sayId();
        var instance2 = new SubType('instance2',2);
        console.log(instance2.color)
        instance2.sayName();
        instance2.sayId();
    </script>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容