再起航,我的学习笔记之JavaScript设计模式06(工厂方法模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧!
上一次已经给大家介绍了简单工厂模式,相信大家对创建型设计模式有了初步的了解,本次我将给大家介绍的是工厂方法模式。
工厂方法模式
工厂方法模式(Factory Method):通过对产品类的抽象使其创建业务主要负责用于创建多类产品的实例。
这样说起来可能还是有很多人不理解,那么我们开始用示例来演示工厂方法模式吧
假如我们需要做一个商城的项目商城的项目里有很多板块,比如蔬果区,生鲜区,日用百货区,等等一些,他们可能所在的区域在页面中主色调完全不一样,按照我们之前分享的简单工厂模式的做法,我们也许会这样做。
创建一个蔬果区
var Vegetable=function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var vegetable=document.createElement('div');
vegetable.innerHTML=content;
vegetable.style.color='green';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(vegetable);
})(content)
}
接着我们创建一个生鲜区
var Fresh=function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var fresh=document.createElement('div');
fresh.innerHTML=content;
fresh.style.color='blue';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(fresh);
})(content)
}
最后我们再创建一个日用百货区
var DailyProvisions=function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var dailyProvisions=document.createElement('div');
dailyProvisions.innerHTML=content;
dailyProvisions.style.color='gray';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(dailyProvisions);
})(content)
}
现在我们创建一个商城类工厂
var mallFactory=function (name,text){
switch(name){
case 'Vegetable':
return new Vegetable(text);
case 'Fresh':
return new Fresh(text);
case 'DailyProvisions':
return new DailyProvisions(text);
}
}
最后我们测试一下
var vegetableTest=mallFactory("Vegetable","蔬果区");
var vegetableTest=mallFactory("Fresh","生鲜区");
var vegetableTest=mallFactory("DailyProvisions","日用百货区");
我们看到在页面上显示成功

但是这个时候如果我们想要在加一个家电区,要用不同的颜色代替,我们会发现,我们不仅要新建一个家电类,还要在商城的工厂里添加对应的类型,会很麻烦,那么这个时候我们就可以用工厂方法模式。
首先我们来创建一个工厂类
var Factory=function(type,content){
if(this instanceof Factory){
var o=new this[type](content);
return o;
}else{
return new Factory(type,content);
}
}
接着我们把我们需要创建的所有类型的父类添加到我们的工厂里去
Factory.prototype={
Vegetable:function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var vegetable=document.createElement('div');
vegetable.innerHTML=content;
vegetable.style.color='green';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(vegetable);
})(content)
},
Fresh:function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var fresh=document.createElement('div');
fresh.innerHTML=content;
fresh.style.color='blue';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(fresh);
})(content)
},
DailyProvisions:function(content){
this.content=content;
//创建闭包对象,直接执行,将内容样式直接插入页面
(function(content){
var dailyProvisions=document.createElement('div');
dailyProvisions.innerHTML=content;
dailyProvisions.style.color='gray';
//我们页面会定义个id名为container的区域放置这些模块
document.getElementById('container').appendChild(dailyProvisions);
})(content)
}
}
这样我们就建立了一个工厂方法,现在我们要在想添加一个父类就可以直接添加在工厂里了,是不是方便很多,下面我们试着调用一下。
var data=[
{name:'Vegetable',text:'蔬果区'},
{name:'Fresh',text:'生鲜区'},
{name:'DailyProvisions',text:'日用百货区'}
]
for(var i=0;i<data.length;i++){
Factory(data[i].name,data[i].text);
}

我们再来看一下结果,得到的结果都是一样的,但是如果还需要添加基类,就只用想我们的工厂方法里添加一次就够了。
也谢谢大家看到这里:)如果你觉得我的分享还可以请点击推荐,分享给你的朋友让我们一起进步~
好了以上就是本次分享的全部内容,本次示例参考自JavaScript设计模式一书,让我们一点点积累一点点成长,希望对大家有所帮助。
欢迎转载,转载请注明作者,原文出处。
再起航,我的学习笔记之JavaScript设计模式06(工厂方法模式)的更多相关文章
- 再起航,我的学习笔记之JavaScript设计模式05(简单工程模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...
- 再起航,我的学习笔记之JavaScript设计模式06(抽象工厂模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...
- 再起航,我的学习笔记之JavaScript设计模式30(简单模板模式)
简单模板模式 概念介绍 简单模板模式(Simple template): 通过格式化字符串拼凑出视图避免创建视图时大量节点操作,优化内存开销. 创建模板 在实际的业务中如果我们需要进行前后台交互,或多 ...
- 再起航,我的学习笔记之JavaScript设计模式13(装饰者模式)
装饰者模式 装饰者模式(Decorator): 在不改变原对象的基础上,通过对其进行过包装拓展(添加属性高或者方法)使原有对象可以满足用户的更复杂需求. 如果现在我们有个需求,需要做一个提交表单,当我 ...
- 再起航,我的学习笔记之JavaScript设计模式23(中介者模式)
中介者模式 概念介绍 中介者模式(Mediator):通过中介者对象封装一系列对象之间的交互,使对象之间不再相互引用降低他们之间的耦合,有时中介者对象也可以改变对象之间的交互. 创建一个中介 中介者模 ...
- 再起航,我的学习笔记之JavaScript设计模式16(享元模式)
### 享元模式 **享元模式(Flyweight):** 运用共享技术有效地支持大量的细粒度的对象,避免对象间拥有相同内容造成多余的开销. 上回我们在组合模式中创建了文章列表类,这次我们要向不同的文 ...
- 设计模式C++学习笔记之五(Factory Method工厂方法模式)
工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中.核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的 ...
- 再起航,我的学习笔记之JavaScript设计模式05(简单工厂模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...
- 再起航,我的学习笔记之JavaScript设计模式07(抽象工厂模式)
我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...
随机推荐
- [leetcode-553-Optimal Division]
Given a list of positive integers, the adjacent integers will perform the float division. For exampl ...
- 【Android Developers Training】 0. 序言:构建你的第一个应用
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- example001点击隐藏
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Http异步发送之HttpWebRequest的BeginGetResponse
关于http异步发送,一开始我的做法都是用thread或者task去完成的:后来发现HttpWebRequest本身就提供一个异步的方法. 总感觉.Net自己提供的异步方法可能要优于我们自己用线程去实 ...
- 关闭chrome浏览器的developer tools
背景 Chrome使用过程中,很容易启动Chrome developer tools,一些误触如按到F12.CTRL+Shift+C等都会启动developer tools.对于不开发Web的人来说, ...
- Object-C知识点 (四) 性能优化
#pragma mark - 性能优化 1. 行高一定要缓存 缓存行高是解决性能优化的最佳途径(除非刷新频率已经很高了,否则一定要缓存)2. 尽量减少计算,所有需要素材提前计算好3. 控件不要设置圆角 ...
- vijos1027题解
题目: 当大家在考场中接受考验(折磨?)的时候,小呆正在悠闲(欠扁)地玩一个叫"最初梦想"的游戏.游戏描述的是一个叫pass的有志少年在不同的时空穿越对抗传说中的大魔王chines ...
- 使用C#在VS中开发:未处理AccessViolationException “System.AccessViolationException”类型的未经处理的异常
未处理AccessViolationException: “System.AccessViolationException”类型的未经处理的异常在System.Data.dll中发生 其他信息:尝试读 ...
- Win8.1下VM与Hyper-v冲突解决方法
不需要使用hyperv.去程序那里关闭hyperv.要同时使用两中虚拟机.使用折中的办法: 创建两个启动菜单,在启动的时候选择是否要运行 Hyper-V. 管理员身份运行命令提示符 cmd 输入 b ...
- 18-EasyNetQ:发生错误的情况
这一篇文章让我们看看在消息系统中可能发生的各种错误的情况下,看下EasyNetQ如何处理它们. 订阅服务挂了 当你写了一个windows 服务,用来订阅一个NewCustomerMessage消息. ...