我的学习笔记是根据我的学习情况来定期更新的,预计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. meta小结

    mate 标签定义及使用说明 元数据(Metadata)是数据的数据信息. 标签提供了 HTML 文档的元数据.元数据不会显示在客户端,当时会被浏览器解析. META元素通常用于指定网页的描述,关键词 ...

  2. 前端自动化测试python+webdriver

    前言:很多做测试的朋友的就知道,python+webdriver  可以做自动化测试,这对前端开发是非常有用的.  python 入门我就不讲了  ,推荐学习 廖雪峰老师的python入门3.5新版哈 ...

  3. JVM总结之GC

    哪些内存需要回收 在Java堆中存放着几乎所有的对象实例,垃圾收集器在对堆进行回收前,第一件事情就是要知道哪些对象还"存活着",哪些对象已经"死去". 引用计数 ...

  4. java语言中的匿名类与lambda表达式介绍与总结 (Anonymous Classes and Lambda Expressions)

    2017/6/30 转载写明出处:http://www.cnblogs.com/daren-lin/p/anonymous-classes-and-lambda-expressions-in-java ...

  5. h5 新增特性用法---持续更新

    1.dataset <div class="box" data-title1="自定义属性" data-age="18" data-m ...

  6. 平板点餐软件编程体会---记我的Android编程之路

    前言 想开发一个平板点餐系统,研究下陈江根大侠分享的一个很高水准的实例,只是个单机版无实用意义. (如需运行源码请回复联系邮箱) 实现 Mysql 数据库+Tomcat WEb服务器,使用Servle ...

  7. 【Unity与23种设计模式】状态模式(State)

    定义: "让一个对象的行为随着内部状态的改变而变化,而该对象也像是换了类一样" 应用场景: 角色AI:控制角色在不同状态下的AI行为 服务器连接状态:开始连线.连线中.断线等状态 ...

  8. springmvc(四) springmvc的数据校验的实现

    so easy~ --WH 一.什么是数据校验? 这个比较好理解,就是用来验证客户输入的数据是否合法,比如客户登录时,用户名不能为空,或者不能超出指定长度等要求,这就叫做数据校验. 数据校验分为客户端 ...

  9. 是什么优化让 .NET Core 性能飙升?

    .NET Core(开放源代码,跨平台,x-copy可部署等)有许多令人兴奋的方面,其中最值得称赞的就是其性能了. 感谢所有社区开发人员对.NET Core做出的贡献,其中的许多改进也将在接下来的几个 ...

  10. C# Web.config配置

    使用 <!--M002 バッチを起動のPath配置--> <add key="BM0002_START_PATH" value="D:\BM0002\B ...