广告展现

例如,关于计算机培训广告资源需要投放,一批是Java的用绿色字体,一批是PHP的,用黄色字体,红色背景。

// 创建Java学科类
var Java = function (content) {
// 将内容保存在content里面以备后面使用
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.color = 'green';
document.getElementById('container').appendChild(div);
})(content);
} // 创建PHP学科类
var Php = function(content) {
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.color = 'yellow';
div.style.background = 'red';
document.getElementById('container').appendChild(div);
})(content);
}

刚写完,又来了一批广告,关于JavaScript的,要求背景色是粉色的,于是用简单工厂模式来实现。

// 创建Java学科类
var Java = function (content) {
// 将内容保存在content里面以备后面使用
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.color = 'green';
document.getElementById('container').appendChild(div);
})(content);
} // 创建PHP学科类
var Php = function(content) {
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.color = 'yellow';
div.style.background = 'red';
document.getElementById('container').appendChild(div);
})(content);
} // 创建javascript学科类
var Javascript = function(content) {
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.background = 'pink';
document.getElementById('container').appendChild(div);
})(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);
}
}
// 测试示例
new Jobfactory('Javascript','javascript哪家强!')

刚写完不久,又来了一批广告,UI学科的,需要红色边框.... 沉默了....

方案的择决

现在我发现,只要每次新来一批广告 ,我除了要添加类,还要修改工厂函数,这个时候工厂方法模式就出现了。我们可以将工厂方法看做是一个实例化对象的工厂类。安全起见,采用安全模式类。

安全模式类

安全模式类解决如下示例问题:

var Demo = function() {}
Demo.prototype = {
show: function() {
console.log('成功获取');
}
} var d = new Demo();
d.show(); // 成功获取 var d2 = Demo();
d2.show(); // Uncaught TypeError: Cannot read properties of undefined (reading 'show')

为了避免出现上述问题,我们在构造函数开始执行时候,先判断当前对象this指代的是不是类(Demo),我们永生instanceof判断。

var Demo = function() {
if(!(this instanceof Demo)) {
return new Demo();
}
}
Demo.prototype = {
show: function() {
console.log('成功获取');
}
} var d = new Demo();
d.show(); // 成功获取 var d2 = Demo();
d2.show(); // 成功获取

有了安全模式,我们就可以把这种技术应用到工厂方法中。

安全的工厂方法

// 安全模式创建的工厂类
var Factory = function(type,content) {
if(this instanceof Factory) {
return new this[type](content);
} else {
return new Factory(type,content);
}
} // 工厂原型中设置创建所有类型数据对象的基类
Factory.prototype = {
Java: function(content) { },
php: function(content) { },
Javascript: function(content) { },
UI: function(content) {
this.content = content;
(function(content){
var div = document.createElement('div');
div.innerHTML = content;
div.style.border = '1px solid red';
document.getElementById('container').appendChild(div);
})(content);
}
} // 示例
Factory('UI','UI哪家强')

这样如果我们后面想其他其他类,只需要写在Factory这个工厂类的原型里面就可以了。

这就好比你在Factory类的原型上注册了一张名片,以后需要哪个类,只需要拿着这张名片,查找上面的信息就能找到这个类了。所有就不用担心使用的时候到不到基类了。

我们也可以这样使用:

// 示例
var data = [
{type: 'Javascript',content: 'Javascript哪家强'},
{type: 'Javascript',content: 'Javascript哪家强'},
{type: 'php',content: 'php哪家强'},
{type: 'UI',content: 'UI哪家强'},
{type: 'UI',content: 'UI哪家强'}
] for(var i = 0; i < data.length; i++) {
Factory(data[i].type,data[i].content);
}

【JS设计模式笔记】给我一张名片-工厂方法模式(创建型)的更多相关文章

  1. C#面向对象设计模式纵横谈——5.Factory Method 工厂方法模式(创建型模式)

    动机 (Motivation) 在软件系统中,经常面临着“某个对象”的创建工作; 由于需求的变化,这个对象经常面临着剧烈的变化,但是它却拥有比较稳定的接口. 如何应对这种变化?如何提供一种“封装机制” ...

  2. 设计模式(3)--FactoryMethod( [2] 工厂方法模式)--创建型

    1.模式定义: 工厂方法是针对每一种产品提供一个工厂类.通过不同的工厂实例来创建不同的产品实例. 2.模式特点: (1)工厂方法模式去掉了简单工厂模式中工厂方法的静态属性,使得它可以被子类继承. (2 ...

  3. Java设计模式从精通到入门五 抽象工厂方法模式

    定义 抽象工厂类为创建一组相关和相互依赖的对象提供一组接口,而无需指定一个具体的类. ​ 这里我得把工厂方法模式得定义拿出来做一下比较:定义一个创建对象的接口,由子类决定实例化哪一个类.工厂方法是一个 ...

  4. [设计模式]<<设计模式之禅>>工厂方法模式

    1 女娲造人的故事 东汉<风俗通>记录了一则神话故事:“开天辟地,未有人民,女娲搏黄土做人”,讲述的内容就是大家非常熟悉的女娲造人的故事.开天辟地之初,大地上并没有生物,只有苍茫大地,纯粹 ...

  5. Java设计模式系列-工厂方法模式

    原创文章,转载请标注出处:<Java设计模式系列-工厂方法模式> 一.概述 工厂,就是生产产品的地方. 在Java设计模式中使用工厂的概念,那就是生成对象的地方了. 本来直接就能创建的对象 ...

  6. 再起航,我的学习笔记之JavaScript设计模式06(工厂方法模式)

    上一次已经给大家介绍了简单工厂模式,相信大家对创建型设计模式有了初步的了解,本次我将给大家介绍的是工厂方法模式. 工厂方法模式 工厂方法模式(Factory Method):通过对产品类的抽象使其创建 ...

  7. Java设计模式学习笔记(三) 工厂方法模式

    前言 本篇是设计模式学习笔记的其中一篇文章,如对其他模式有兴趣,可从该地址查找设计模式学习笔记汇总地址 1. 简介 上一篇博客介绍了简单工厂模式,简单工厂模式存在一个很严重的问题: 就是当系统需要引入 ...

  8. C#设计模式学习笔记:(2)工厂方法模式

    本笔记摘抄自:https://www.cnblogs.com/PatrickLiu/p/7567880.html,记录一下学习过程以备后续查用. 一.引言 接上一篇C#设计模式学习笔记:简单工厂模式( ...

  9. 【JS设计模式】温习简单工厂模式、工厂方法模式、抽象工厂模式概念

    注:空心箭头表示的是种继承关系,工厂类和产品类之间是一种依赖关系.是用箭头加虚线表示的,以下的模型图是用的实线是不正确(时间不够用,在这里我偷懒了.这个习惯不好,呵呵) 简单工厂模式(Simple F ...

  10. Android设计模式系列--工厂方法模式

    工厂方法模式,往往是设计模式初学者入门的模式,的确,有人称之为最为典型最具启发效果的模式.android中用到了太多的工厂类,其中有用工厂方法模式的,当然也有很多工厂并不是使用工厂方法模式的,只是工具 ...

随机推荐

  1. 教你基于MindSpore用DCGAN生成漫画头像

    本文分享自华为云社区<[昇思25天学习打卡营打卡指南-第二十天]DCGAN生成漫画头像>,作者:JeffDing. DCGAN生成漫画头像 在下面的教程中,我们将通过示例代码说明DCGAN ...

  2. CF-957(D-E)

    CF-957 赛时A去写全排列--前三题我的写法都挺丑的,后面改进了再更-- Problem - D - Codeforces 虽然是很简单很经典的线性dp,但也是我第一次自己把这种题写出来ヾ(≧▽≦ ...

  3. [oeasy]python0026_刷新时间_延迟时间_time_sleep_死循环_while_True

    ​ 刷新时间 回忆上次内容 time 是一个 ​​module​ import 他可以做和时间相关的事情 time.time() 得到当前时间戳 time.localtime() 得到本地时间元组 l ...

  4. 全网最好看的单细胞umap图绘制教程

    全网最好看的单细胞umap图绘制教程 作者按 大家或许都曾被Nature, Science上的单细胞umap图吸引过,不免心生崇拜.在这里,我们将介绍一种简单方便的顶刊级umap图可视化 全文字数|预 ...

  5. 助动词&情态动词

    助动词 (auxiliary verbs) 任何整句都分为主语和谓语,而谓语部分的核心是谓语动词, 但是谓语动词本身往往无法独立表达某些语法概念,需要其他词的辅助, 而这类来辅助构成谓语但自己本身不能 ...

  6. 【Vue】Re07 插槽Slot

    一.插槽基本使用 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  7. 【Redis】RCMD 04 List 列表

    1.LPUSH 写入命令:   LPUSH 键 值1 值2 值3 值4 ... 127.0.0.1:6379[12]> LPUSH LIST-1 1 2 3 4 5 (integer) 5 2. ...

  8. 如何理解自动驾驶的分级:L0、L1、L2、L3、L4、L5

    相关: https://baijiahao.baidu.com/s?id=1792281493472406727&wfr=spider&for=pc L0,就是完全没有自动驾驶技术的车 ...

  9. 《Python数据可视化之matplotlib实践》 源码 第一篇 入门 第一章

    最近手上有需要用matplotlib画图的活,在网上淘了本实践书,发现没有代码,于是手敲了一遍,mark下. 第一篇    第一章 图1.1 import matplotlib.pyplot as p ...

  10. 公共的网络云盘的存储真的安全吗?—— 百度云盘上的PDF文件无故被改名

    在百度云盘上上传了一个PDF文件,内容: 本来是没有啥问题的,但是今天使用百度云盘发现这个PDF文件居然被改名,被取消掉了扩展名: 简直是离谱离了一个大谱,太可怕了,看来这种公共云盘真的不太靠谱,虽然 ...