这里主要介绍两种工厂模式,第一种“简单工厂模式”,第二种“工厂方法模式”

简单工厂模式

1.定义

由一个工厂对象决定对象创建某一种产品对象的的实例。主要用来创建同一类对象。

2.具体需求

现在有一个登录模块,当用户的输入的用户名多于16个时,给一个警示弹窗

var LoginAlert = function(text) {
this.content = text
} LoginAlert.prototype.show = function() {
//显示警示框
}
var userNameAlert = new LoginAlert('用户名不能多于16个字母或数字')
userNameAlert.show()

当用户输入的密码不正确时,给一个密码不正确的弹窗,心中暗喜,面对对象编程真好用,刚刚学完的类就能派上用场

var passwordAlert = new LoginAlert('输入的密码啊不正确')
passwordAlert.show();

新需求:当用户登录时用户名不存在的时候弹窗提示“您的用户名不存在,请重新输入”,并在警示框上加一个注册按钮,完了,之前的累无法复用,又得创建一个类

var LoginConfirm = function(text) {
this.content = text
} LoginConfirm.prototype.show = function() {
//显示确认框
}
var loginFailConfrim = new LoginConfirm('您的用户名不存在,请重新输入')
loginFailConfrim.show()

新需求:当用户登录成功的时候给一个弹窗,除了有确认按钮和取消按钮,也提示一句‘欢迎回来,请输入您的心情’,这又得写一个新类

var LoginPrompt = function(text) {
this.content = text
} LoginPrompt.prototype.show = function() {
//显示确认框
}

新需求:现在有注册模块也要做,也有这些需求,这时候我们应该怎么办呢?

我们这个把这三个类封装在一个函数里,这时候我们只需要记住这个函数,然后通过这个函数就可以创建我们需要的对象,这样所有使用的人都不在关注这些对象到底依赖于哪些基类,我们知道这个函数就可以。这个函数我们通常也称为工厂函数,这种模式叫简单工厂模式,是工厂模式中最简单的一种形式

如何改造:

var PopFactory = function(name) {
switch(name) {
case 'alert':
return new LoginAlert();
case 'confirm':
return new LoginConfirm();
case 'prompt':
return new LoginPrompt();
}
}

这样我们就实现了一个简单的工厂,使用者只要知道这个工厂和参数就行,但是这3个类用很多公有的方法,能不能提取出来?

现在我们把这三个类改成一个工厂模式,首先抽象他们的相同点,不如共有属性this.content,原型共有方法show,当然也有不同点,比如确认框和提示框的确定按钮,提示框的用户输入等等

function createPop(type, text) {
var o = new Object();
o.content = text;
o.show = function() {
//显示方法
}
if (type == 'alert') { }
if (type == 'prompt') { }
if (type == 'confirm') { }
}
//创建警示框
var userNameAlert = createPop('alert', '用户名只能是26个字母和数字')

总结:团队开发不同于个人开发,其对全局变量限制很大,所以我们要尽量少的创建全局变量。对于同一类对象在不同需求中的重复性使用,很多时候不需要重复创建,代码复用是面向对象的一条准则

2.工厂方法模式

定义

通过对产品类的抽象使其创造业务只要负责用户创建多类产品的实例

具体需求

网站首页要展示一个大批学科,字体和颜色不一

var Java = function(content) {
this.content = content
(function() {
var div = document.createElement('div')
div.innerHtml = content;
div.style.color = 'green';
dicument.getElementById('container').appendChild('div')
})(content)
} var Php = function(content) {
//....
}

上节课学过的简单工厂模式派上了用场,赶紧去用简单的工厂模式去实现一下,这样以后再创建对象直接找工厂就行

var Java = function(content) {
this.content = content
(function() {
var div = document.createElement('div')
div.innerHtml = content;
div.style.color = 'green';
dicument.getElementById('container').appendChild('div')
})(content)
} var Php = function(content) {
//....
} var JavaScript = function(content) {
//...
} function JobFactory(type, content) {
switch(type) {
case: 'java':
return new Java(content)
case: 'php':
return new Php(content)
case: 'javascript':
return new JavaScript(content)
}
}

新需求:现在又需要加一批UI学科,红色边框。

问题:需求一直在变,开始需求简单,直接创建对象,后来需求多了,用简单方法工厂方法重构,现在又变了,不仅仅要添加类,还要修改工厂函数,很麻烦,现在引入我们的工厂方法来解决这个问题

Factory.prototype = {
Java:function(content) {
//...
},
JavaSctipt:function(content) {
//...
},
Java: function(content) {
//...
}
}

这样我们如果要添加其他的类,只需要写在Factory这个工程类里面就行了

安全的工厂方法

安全的工厂方法是可以屏蔽一些使用过程中造成的错误,我们知道类前面不要有new的关键字,不过如果其他人不知道这个对象是一个雷,忽略了new关键字直接执行,此时得不到我们预期的对象,解决办法如下

var Factory = function(type, content) {
if (this instanceof Factory) {
var s = new this[type](content)
return s
} else {
return new Factory(type, content)
}
}
Factory.prototype = {
Java:function(content) {
//...
},
JavaSctipt:function(content) {
//...
},
Java: function(content) {
//...
}
}

Javascript工厂模式介绍到此结束,有不对的地方请及时指出

浅析JavaScript工厂模式的更多相关文章

  1. javascript工厂模式和构造函数模式创建对象

    一.工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程(本书后面还将讨论其他设计模式及其在JavaScript 中的实现).考虑到在ECMAScript 中无法创 ...

  2. javascript工厂模式

    工厂模式 设计工厂模式的目的是为了创建对象.它通常在类或者类的静态方法实现,具有下列目标: 1.在创建相似对象是执行重复操作 2.在编译时不知道具体类型(类)的情况下,为工厂客户提供一种创建对象的接口 ...

  3. javascript工厂模式、单例模式

    //工厂模式 function createObject(name,age){ var obj = new Object(); obj.name = name; obj.age = age; obj. ...

  4. JavaScript 工厂模式和订阅模式

    设计模式的好处: 代码规范 // 例如表单验证,两个 input ,一个用户名,一个密码 // 通常做法是 function checkUser(){ //..... } function check ...

  5. JavaScript 工厂模式

    //工厂 function FruitMaker() { //function 后不带方法名,这里cococola未定义,make return时,返回 FruitMaker.cococola thi ...

  6. JavaScript工厂模式代码

    function createPerson(name,age,job){ var o=new Object(); o.name=name; o.age=age; o.job=job; o.sayNam ...

  7. js工厂模式和构造函数

    <!DOCTYPE html><html><head> <title>工厂模式和构造函数</title> <meta charset ...

  8. javascript 设计模式-----工厂模式

    所谓的工厂模式,顾名思义就是成批量地生产模式.它的核心作用也是和现实中的工厂一样利用重复的代码最大化地产生效益.在javascript中,它常常用来生产许许多多相同的实例对象,在代码上做到最大的利用. ...

  9. javascript模式 (3)——工厂模式和装饰模式

    上节我们讲解了单例模式,这节我们将继续讲解工厂模式和迭代器模式 工厂模式: 工厂模式的目的是为了方便的创建对象(可以在不知道构造的情况下),通过静态方法来实现,在java或c#等静态编译语言中需要通过 ...

随机推荐

  1. Windows下Flume的安装

    flume(日志收集系统) Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集.聚合和传输的系统,Flume支持在日志系统中定制各类数据发送方,用于收集数据:同时,Flum ...

  2. 详解node + mongoDb(mongoDb安装、运行,在node中连接、增删改查)

    一.序言 好久没写博客了,这次主要聊聊 node 和 mongoDb . 先说明一下技术栈  node + express + mongoose + mongoDb.这篇博客,主要讲述 mongoDb ...

  3. CentOS 编译安装 Redis (实测 笔记 Centos 7.3 + redis 3.2.8)

    环境: 系统硬件:vmware vsphere (CPU:2*4核,内存2G,双网卡) 系统版本:CentOS-7.0-1406-x86_64-DVD.iso 安装步骤: 1.准备 1.1 显示系统版 ...

  4. 3.ifconfig

    Windows下查看IP地址用ipconfig Linux 下查看IP地址用ifconfig 还有 ip addr      而ipconfig 和ip addr的区别则是与net-tools工具和i ...

  5. 虚拟机桥接模式联网方法,Xshell的连接与使用

    1.虚拟机的编辑中的虚拟网络编译器,新建一个VMnet0,选择桥接模式,选择上网时的网卡. 2.虚拟机 -> 设置 -> 网络适配器,选择启动时连接,桥接模式,复制物理网络连接状态. 3. ...

  6. hadoop基础操作

    通过hadoop上的hive完成WordCount 启动hadoop Hdfs上创建文件夹 上传文件至hdfs 启动Hive 创建原始文档表 导入文件内容到表docs并查看 用HQL进行词频统计,结果 ...

  7. Mesos源码分析(7): Mesos-Slave的启动

      Mesos-Slave的启动是从src/slave/main.cpp中的main函数开始的.   看过了Mesos-Master的启动过程,Mesos-Slave的启动没有那么复杂了.   1. ...

  8. React-Native的基本控件属性方法,对React-Native的学习,从熟悉基本控件开始。

    对React-Native的学习,从熟悉基本控件开始. View 属性方法 序号 名称 属性Or方法 类型 说明 1 accessibilityLabel 属性 string   2 accessib ...

  9. 【DFS】数独游戏

    DFS(深度优先搜索): 深度优先搜索算法(英语:Depth-First-Search,简称DFS)是一种用于遍历或搜索树或图的算法. 沿着树的深度遍历树的节点,尽可能深的搜索树的分支.当节点v的所在 ...

  10. [Swift]LeetCode188. 买卖股票的最佳时机 IV | Best Time to Buy and Sell Stock IV

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...