js装饰者模式

二.装饰者模式

//定义构造函数(类)

function People(id,name,sex){

    this.id=id;
    this.name=name;
    this.sex=sex;

}

 //类开始的初始方法

    People.prototype.getInfo=function(){
        return "编号:"+this.id;
    }


    //扩张装饰方法
    People.prototype.decorate=function(str){
        //获得装饰者对象
        var override=this.constructor.decorates[str];
        //创建一个新的对象,这个对象继承this
         var f=function(){};
        f.prototype=this;
        var instance=new f();
        instance.uber= f.prototype;
        //将装饰者的方法添加到这个新建的对象中
        for(i in override){
            if(override.hasOwnProperty(i)){
                instance[i]=override[i];
            }
        }
        return instance;

    }

//装饰者对象都将以构造函数的属性这种方式实现

    People.decorates={};

装饰者对象

    People.decorates.name={
        getInfo:function(){
            var info=this.uber.getInfo();
            return info+="\n名字:"+this.name;
        }

    }

装饰者对象

    People.decorates.sex={
        getInfo:function(){
            var info=this.uber.getInfo();
            return info+="\n性别:"+this.sex;
        }

    }



调用:
var my=new People('01','cyt','男');
    my=my.decorate('name');
    my=my.decorate('sex');

    console.log(my.getInfo());

=========================

//编号:01
//名字:cyt
//性别:男

=========================




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值