美文网首页
分即是合-----建造者模式

分即是合-----建造者模式

作者: 前端Tree | 来源:发表于2022-11-17 22:01 被阅读0次
    /**
     * 建造者模式。关心的是创建对象的整个过程,比如我们创建一个人,
     * 我们创建的结果不仅仅要得到人的实例,还要关注创建人的时候,这个人应该穿什么衣服
     * 男的还是女的,兴趣爱好是什么。
     * 下面我们创建一位应聘者的实例
     */
    // 创建一位人类
    var Human = function (param) {
        // 技能
        this.skill = param && param.skill || '保密';
        // 兴趣爱好
        this.hobby = param && param.hobby || '保密';
    }
    
    // 类人原型方法
    Human.prototype = {
        getSkill: function () {
            return this.skill;
        },
        getHobby: function() {
            return this.hobby
        }
    }
    
    // 实例话姓名类
    var Named = function(name) {
        var that = this;
        // 构造器
        // 构造函数解析姓名的姓和名
        (function(name,that){
            that.wholeName = name
            if(name.indexOf(' ') > -1) {
                that.FirstName = name.slice(0, name.indexOf(' '))
                that.secondName = name.slice(name.indexOf(' ') + 1);
            }
        })(name,that)
    }
    // 实例话职位类
    var Work = function(work) {
        var that = this;
        // 构造器
        // 构造函数中通过传入的职位特征来设置相应的职位以及描述
        (function() {
            switch(work) {
                case 'code':
                    that.work = '工程师';
                    that.wordDescript = '每天沉醉于变成';
                    break;
                case 'UI':
                case 'UE':
                    that.work = '设计师';
                    that.workDescript = '设计更似一种艺术';
                    break;
                case 'teack':
                    that.work = '教师';
                    that.workDescript = '分享也是一种快乐';
                    break;
                default: 
                    that.work = 'work';
                    that.workDescript = '对不起,我们还不清楚您所选择职位的相关描述';
                    break;
            }
        })(work,that)
    }
    
    // 更换期望的职位
    Work.prototype.changeWork = function (work) {
        this.work = work
    }
    
    // 添加对职位的描述
    Work.prototype.changeDescript = function(setence) {
        this.wordDescript = setence
    }
    
    /**
     * 应聘者建造者
     * 参数 name : 姓名(全名)
     * 参数 work : 期望职位
     */
    var Person = function (name, work) {
        // 创建应聘者缓存对象
        var _person = new Human()
        // 创建应聘者姓名解析对象
        _person.name = new Named(name);
        // 创建应聘者期望职位
        _person.work = new Work(work)
        // 将创建应聘者对象返回
        return _person
    }
    
    // 使用应聘者建造者
    var person = new Person('wang yahao', 'code')
    
    // 测试看看
    console.log(person.skill)
    console.log(person.name.FirstName)
    console.log(person.work.work)
    console.log(person.work.wordDescript)
    person.work.changeDescript('更改一下职位描述')
    console.log(person.work.wordDescript)
    
    
    

    相关文章

      网友评论

          本文标题:分即是合-----建造者模式

          本文链接:https://www.haomeiwen.com/subject/jexmxdtx.html