再起航,我的学习笔记之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天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前两 ...
随机推荐
- 引入CSS文件的方式,以及link与@import的区别
一.引入css的方式 在HTML中引入css的方法主要有4种:行内式.内嵌式.链接式和导入式. 1.行内式 <div style="background:yellow;"&g ...
- 我眼中的ASP.NET Core之微服务
### 前言 前几天在博客园看到有园友在分享关于微软的一个微服务架构的示例程序,想必大家都已经知道了,那就是[eShopOnContainers](https://github.com/dotnet- ...
- python自动化运维学习第一天--day1
学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...
- 【原创】 Docker 中 运行 ASP.NET Core 站点
一. 建立 .NetCore 项目 a.新建项目 b.选择项目类型 c.添加控制器 d.添加视图 e.修改默认请求 f.发布 二. 准备 CentOS 环境 a.准备虚拟机 b.安装 docker ...
- 简约的HTML5音乐播放器插件
从我刚开始接触前端的时候就想写一个能播放音乐的小程序,刚开始写的时候虽然可以放,但是确实很慢,很卡,有很多可以优化的地方.最近在前一个版本的基础上重写了一个音乐播放器的插件,速度还可以吧 因为追求简约 ...
- 极客圈(一)树莓派3B协同Python打造个性化天气闹钟
人生苦短,我用Python~ 一直想自己折腾些极客的东西出来,供自己使用或者是供他人使用.一则可能对自己的生活是一种帮助,二则是对自己技能的提高,三则显得高大上,一直努力,一直提高,一直Happy!~ ...
- angular popover的触发问题;
popover 一般如下用法; <div uib-popover="内容" popover-animation="false" popover-appen ...
- javascript精度问题与调整
一个经典的问题: 0.1+0.2==0.3 答案是:false 因为:0.1+0.2=0.30000000000000004 第一次看到这个结果就是无比惊讶,下巴碰到地上,得深入了解下问题出在哪里,该 ...
- MyBatis源码解析【6】SqlSession运行
前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 经过之前的学习我们知 ...
- 面向对象15.3String类-常见功能-获取-1
API使用: 查API文档的时候,有很多方法,首先先看返回的类型 下面的方法函数有的是有覆写Object类的如1.1图,如果没有复写的话是写在1.2图片那里的,如果找到了相对于的方法,可以点击进去可以 ...