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

简单工厂模式

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. 如何让Qt程序在运行时获取UAC权限

    在pro文件中加入以下语句: QMAKE_LFLAGS += /MANIFESTUAC:\"level=\'requireAdministrator\' uiAccess=\'false\' ...

  2. 洛谷p3800:Power收集

    考虑朴素的dp: 对于每一行的每一个点 枚举能到的所有点(类似bzoj1648 比这题简单的dp) 期望时间复杂度O(NMT) 显然是超时做法 那么我们发现只有k个点对答案有贡献 考虑对每一个有权值的 ...

  3. Egret的容器--删除对象,遮罩

    class P91F extends egret.Sprite { public constructor() { super(); this.addEventListener(egret.Event. ...

  4. JUC

    1.Java JUC简介 在Java5.0提供了java.util.concurrent(简称JUC)包,在此包中增加了在并发编程中很常用的实用工具类,用于定义类似于线程的自定义子系统,包括线程池.异 ...

  5. mpvue-docs基于vue来开发微信小程序

    http://mpvue.com/和https://tencent.github.io/wepy/

  6. 【原创】XAF 常见错误以及对应解决方法

    1.Appearance Criteria设置错误 Exception occurs while assigning the 'DetailView, ID:xxx_DetailView' view ...

  7. Spring Cloud 组件 —— feign

    feign 作为一个声明式的 Http Client 开源项目.在微服务领域,相比于传统的 apache httpclient 与在 spring 中较为活跃的 RestTemplate 更面向服务化 ...

  8. laravel5单元测试

    https://www.cnblogs.com/love-snow/articles/7641198.html

  9. python-简单邮件报警

    在scrapy爬虫项目中经常遇到 爬取数据时报错无法及时处理 导致数据爬取不完整 只能先查看log才能发现报错 首先写一个简单的邮件发送模块 """ @file: ema ...

  10. SQL插入数据--数据中的某一列来自本表中的数据

    背景: 项目初期使用的配置库和业务库两种数据库并行,所有配置数据位于配置库,所有业务数据根据不同省份位于不同数据库.由于使用省份越来越多,各省的配置数据也越来越多导致配置库的数据量过于庞大,各省共用一 ...