我的学习笔记是根据我的学习情况来定期更新的,预计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(工厂方法模式)的更多相关文章

  1. 再起航,我的学习笔记之JavaScript设计模式05(简单工程模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

  2. 再起航,我的学习笔记之JavaScript设计模式06(抽象工厂模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...

  3. 再起航,我的学习笔记之JavaScript设计模式30(简单模板模式)

    简单模板模式 概念介绍 简单模板模式(Simple template): 通过格式化字符串拼凑出视图避免创建视图时大量节点操作,优化内存开销. 创建模板 在实际的业务中如果我们需要进行前后台交互,或多 ...

  4. 再起航,我的学习笔记之JavaScript设计模式13(装饰者模式)

    装饰者模式 装饰者模式(Decorator): 在不改变原对象的基础上,通过对其进行过包装拓展(添加属性高或者方法)使原有对象可以满足用户的更复杂需求. 如果现在我们有个需求,需要做一个提交表单,当我 ...

  5. 再起航,我的学习笔记之JavaScript设计模式23(中介者模式)

    中介者模式 概念介绍 中介者模式(Mediator):通过中介者对象封装一系列对象之间的交互,使对象之间不再相互引用降低他们之间的耦合,有时中介者对象也可以改变对象之间的交互. 创建一个中介 中介者模 ...

  6. 再起航,我的学习笔记之JavaScript设计模式16(享元模式)

    ### 享元模式 **享元模式(Flyweight):** 运用共享技术有效地支持大量的细粒度的对象,避免对象间拥有相同内容造成多余的开销. 上回我们在组合模式中创建了文章列表类,这次我们要向不同的文 ...

  7. 设计模式C++学习笔记之五(Factory Method工厂方法模式)

      工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中.核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的 ...

  8. 再起航,我的学习笔记之JavaScript设计模式05(简单工厂模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

  9. 再起航,我的学习笔记之JavaScript设计模式07(抽象工厂模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...

随机推荐

  1. php Base64编码文件二进制流主要使用

    <?php header( "Content-type: image/jpeg"); //$filename='1.jpg'; //$content=file_get_con ...

  2. linux下修改Apache配置文件

    linux下修改host文件host文件存放路径 /etc/hosts 可以用vim编辑 //Apache配置虚拟主机 /usr/local/apache/conf/extra/httpd-vhost ...

  3. java连接mysql源码

    import java.sql.; import java.text.SimpleDateFormat; import java.util.; import java.util.Date; impor ...

  4. 【PHP】震惊,一张图详解递归函数!!!!

    在PHP学习中,递归函数是一个非常重要也是非常难以理解的部分,本博文将通过一张图尽可能演示这个过程,不对之处还请指出

  5. JS实现全选、不选、反选

    思路:1.获取元素.2.用for循环历遍数组,把checkbox的checked设置为true即实现全选,把checkbox的checked设置为false即实现不选.3.通过if判断,如果check ...

  6. maven(二) maven项目构建ssh工程(父工程与子模块的拆分与聚合)

    前一节我们明白了maven是个什么玩意,这一节就来讲讲他的一个重要的应用场景,也就是通过maven将一个ssh项目分割为不同的几个部分独立开发,很重要,加油 --WH 一.maven父工程与子模块的拆 ...

  7. Docker-compose 多个Docker容器管理:以MYSQL和Wordpress为例

    搬砖的陈大师版权所有,转载请注明:http://www.lenggirl.com/tool/docker-compose.html Docker-compose 多个Docker容器管理:以MYSQL ...

  8. Java 数据库编程 ResultSet 的 使用方法

    结果集(ResultSet)是数据中查询结果返回的一种对象,可以说结果集是一个存储查询结果的对象,但是结果集并不仅仅具有存储的功能,他同时还具有操纵数据的功能,可能完成对数据的更新等. 结果集读取数据 ...

  9. JavaScript一个whenReady函数,监听及注册事件

    /** * 传递函数给whenReady(),当文档解析完成且为操作准备就绪时, * 函数将作为文档对象的方法调用 * DOMContentLoaded.readystatechange或load事件 ...

  10. Win8.1下VM与Hyper-v冲突解决方法

    不需要使用hyperv.去程序那里关闭hyperv.要同时使用两中虚拟机.使用折中的办法:  创建两个启动菜单,在启动的时候选择是否要运行 Hyper-V. 管理员身份运行命令提示符 cmd 输入 b ...