js原生设计模式——6复杂对象的构建—Builder建造者模式
2015-11-05 11:08
1076 查看
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>builder</title>
<script type="text/javascript">
//创建一个人类
var Human = function(param){
//skill技能
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;
//构造器函数:解析姓与名(new构造实例时即刻执行此闭包函数)
(function(name,that){
that.wholeName = name;//全名赋值
if (name.indexOf(' ')>-1) {
that.firstName = name.slice(0,name.indexOf(' '));
that.secondName = name.slice(name.indexOf(' '));
};
})(name,that);
};
//创建职位类
var Work = function(work){
var that = this;
//构造器函数:通过传入的职位类设置相应的职位及描述
(function(work,that){
switch(work){
case 'code':
that.work = '软件工程师';
that.workDescript = '每天都在敲代码';
break;
case 'UI':
case 'UE':
that.work = '设计师';
that.workDescript = '设计是一种艺术';
break;
case 'teacher':
that.work = '教师';
that.workDescript = '分享也是一种快乐';
break;
default:
that.work = work;
that.workDescript = 'sorry,we don\'t know your\'s workDescript';
}
})(work,that);
}
//添加更换职位的方法
Work.prototype.changeWork = function(work){
this.work = work;
}
//添加对职位的描述方法
Work.prototype.changeDescript = function(setence){
this.workDescript = setence;
}
//创建一个应聘者builder
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('小 明','code');
console.log(person.skill);
console.log(person.name.firstName);
console.log(person.work.work);
console.log(person.work.workDescript);
person.work.changeDescript('我每天都在快乐的编程学习')
console.log(person.work.workDescript);
//本例已经通过验证
</script>
</head>
<body>
</body>
</html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>builder</title>
<script type="text/javascript">
//创建一个人类
var Human = function(param){
//skill技能
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;
//构造器函数:解析姓与名(new构造实例时即刻执行此闭包函数)
(function(name,that){
that.wholeName = name;//全名赋值
if (name.indexOf(' ')>-1) {
that.firstName = name.slice(0,name.indexOf(' '));
that.secondName = name.slice(name.indexOf(' '));
};
})(name,that);
};
//创建职位类
var Work = function(work){
var that = this;
//构造器函数:通过传入的职位类设置相应的职位及描述
(function(work,that){
switch(work){
case 'code':
that.work = '软件工程师';
that.workDescript = '每天都在敲代码';
break;
case 'UI':
case 'UE':
that.work = '设计师';
that.workDescript = '设计是一种艺术';
break;
case 'teacher':
that.work = '教师';
that.workDescript = '分享也是一种快乐';
break;
default:
that.work = work;
that.workDescript = 'sorry,we don\'t know your\'s workDescript';
}
})(work,that);
}
//添加更换职位的方法
Work.prototype.changeWork = function(work){
this.work = work;
}
//添加对职位的描述方法
Work.prototype.changeDescript = function(setence){
this.workDescript = setence;
}
//创建一个应聘者builder
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('小 明','code');
console.log(person.skill);
console.log(person.name.firstName);
console.log(person.work.work);
console.log(person.work.workDescript);
person.work.changeDescript('我每天都在快乐的编程学习')
console.log(person.work.workDescript);
//本例已经通过验证
</script>
</head>
<body>
</body>
</html>
相关文章推荐
- iphone常用控件之UIScrollView
- monkeyrunner自动化测试工具--UI元素获取
- 使用(获取)Images.xcassets中的图片名,不能直接[UIimage ImageWithName:],应该这样
- 03-27---UIScrollView笔记
- 在kettle6.0中集成插件报错:The type........It is indirectly referenced from required .class files
- 使用RequireJS来加载MooTools Classes
- System.ComponentModel.DataAnnotations 命名空间和RequiredAttribute 类
- UIImageView——IOS显示图片的利器
- 通过UIImageRenderingMode改变工程图片颜色
- IOS疯狂基础之UIImage
- 今天给大家说一个我做UI特效的小技巧,先来看看效果吧(录屏有点渣,所以质量有折扣)
- NGUI__UITexture
- xss ***
- array_unique
- THU2015 fall 2-3 Rebuild
- ios Memory Usage Performance Guidelines
- JAVA笔记系列:字符串操作——string stringbuilder stringbuffer
- THU2015 fall 2-4 Queap
- SoapUI-传递 Respons header 中的值到 Request header
- Android 数据查询query函数参数解析