摘要:设计模式共有种,我今天先来了解一下工厂模式,其他的模式将会在后续的博客中陆续为大家讲解。工厂模式主要分为简单工厂模式和抽象工厂模式。抽象工厂模式抽象工厂模式与简单工厂函数不同的是,抽象工厂函数会先设计好接口,具体的实现在子类中进行。
设计模式
设计模式(design pattern)概念:
是一套反复使用、思想成熟、经过分类和无数实战设计经验的总结。是为了代码可重用、可扩展、可解耦、更容易被人理解和保证代码可靠性。
设计模式共有23种,我今天先来了解一下工厂模式(Factory Pattern),其他的模式将会在后续的博客中陆续为大家讲解。
工厂模式工厂模式,正像它的名字一样,可以像工厂一样生产出我们想要的东西,只要我们提供原料。在我们日常编写代码过程中,很可能,我们不知不觉中就已经使用过工厂模式。我们看一个简单的例子:
//工厂模式很基础的的一个例子 function createPerson (name,age) { var person = new Object(); person.name = name; person.age = age; return person; } var Holz = createPerson ("Holz", "21"); console.log(Holz); /* { age: "21", name: "Holz" } */ var Tom = createPerson ("Tom", "7"); console.log(Tom); /* { age: "7", name: "Tom" } */
在这个函数中,我可以通过传入不同的参数,创建具有不同参数值得对象。可以看到,工厂模式其实很简单。
工厂模式(Factory Pattern)主要分为简单工厂模式和抽象工厂模式。简单工厂模式
简单工厂(Simple Factory Pattern)模式主要用于创建同一类的对象,比如我们创建需要一个身份,老师或者学生。可以通过下面这个函数:
//简单工厂模式。 var simpleCreatePerson = function (type, person) { return this[type](person); } simpleCreatePerson.prototype = { student: function (person) { var Astudent = new Object(); Astudent.name = person.name; Astudent.age = person.age; return Astudent; }, teacher: function (person) { var Ateacher = new Object(); Ateacher.name = person.name; Ateacher.age = person.age; return Ateacher; } } var teacher = new simpleCreatePerson("teacher", {name:"郑老师", age:25 }); var student = new simpleCreatePerson("student", {name:"郑同学", age:21 }); console.log(teacher); /* this is a teacher {name:"郑老师", age: 25} */ console.log(student); /* this is a teacher {name:"郑同学", age: 25} */
我们可以传入不同的 type 比如"student"或“teacher”去创建不同的对象,然后再通过不同的person对象去给里面的属性赋值。无论是"student"或者"teacher"都是person,所以说简单工厂函数就是用来创建同一类对象的不同实例。
上面的代码通过原型_prototype_去添加两个函数,(关于原型的知识,不是一两句可以讲完的,如果不懂得话,大家可以到网上去搜索相关的资料进行了解)然后通过this[type]去选择不同的方法,如果这里不明白的话我可以解释一下,this是一个对象,指向当前函数(在JavaScript里函数是对象),然后this[属性名/方法名] 去调用内部的属性或方法,那么this[type] (person)就是调用对应的方法去实例化一个具体的类(student或teacher)。通过this[type] (person)去调用。
这就是简单工厂函数。
抽象工厂模式 :与简单工厂函数不同的是,抽象工厂函数会先设计好接口,具体的实现在子类中进行。这样看概念有点模糊,我们来看一个例子:
我们定义一个父类,abstractCreatePerson也就是创建一个人,然后这个人有一个自我介绍的方法方法selfIntroduction,那么不同的人就有不同的介绍内容,这个时候我们就可以用到抽象工厂模式:
var abstractCreatePerson = function () {}; abstractCreatePerson.prototype = { selfIntroduction: function () { throw new Error("请先实例化此方法!"); } } var student = Object.create(abstractCreatePerson.prototype); student.selfIntroduction = function () { console.log("I am a sutdent, my name is holz!"); } student.selfIntroduction(); /* I am a sutdent, my name is holz! */ var teacher = Object.create(abstractCreatePerson.prototype); teacher.selfIntroduction = function () { console.log("I am a teacher, my name is xxxx!"); } teacher.selfIntroduction(); /* I am a teacher, my name is xxxx! */
可以看到这段代码,父类 abstractCreatePerson 中先声明了一个方法,然后通过 Object.create() 方法去继承这个父类,(因为这样不会覆盖原有的原型链),然后我们再在子类中去实例化方法,不同的子类就有了不同的实例方法。
这就是工厂模式,他提高了我们代码的可重用性,降低了模块之间的耦合度。
工厂模式,正像它的名字一样,可以像工厂一样生产出我们想要的东西,只要我们提供原料
工厂模式提高了我们代码的可重用性,降低了模块之间的耦合度
工厂模式主要用于创建同一类的对象的不同实例
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/90337.html
摘要:本回内容介绍上一回聊到单例模式,做了一道题,内容不多,比较容易理解。这里其实还可以进一步优化,达到高聚类低耦合,这里工厂模式就告一段落了。 本回内容介绍 上一回聊到JS单例模式(singleton),做了一道题,内容不多,比较容易理解。介一回嘞,聊聊工厂模式,之前聊到过工厂模式,这回聊深入点儿,可能会比较抽象,不过好在实际开发中使用还算广泛,理解起来会比较容易,开始咯: 1. 简单工厂...
摘要:注意事项声明函数时候处理业务逻辑区分和单例的区别,配合单例实现初始化构造函数大写字母开头推荐注意的成本。简单工厂模式使用一个类通常为单体来生成实例。 @(书籍阅读)[JavaScript, 设计模式] 常见设计模式 一直对设计模式不太懂,花了一下午加一晚上的时间,好好的看了看各种设计模式,并总结了一下。 设计模式简介 设计模式概念解读 设计模式的发展与在JavaScript中的应用 ...
摘要:简单工厂模式创建单一的对象示例描述工厂模式主要是为了创建对象实例或者类簇抽象工厂关心的是最终产出创建的对象而不关心创建的过程在出现多个类的时候每次创建需要找到对应的类往往比较麻烦这时候通常使用一个函数进行封装来创建所需要的对象这样就无需关注 简单工厂模式(创建单一的对象) 示例1 描述 工厂模式主要是为了创建对象实例或者类簇(抽象工厂), 关心的是最终产出(创建)的对象, 而不关心创建...
摘要:设计模式工厂模式最近阅读了几本设计模式方面的书籍学习之余整理下来方便以后的归纳和梳理设计模式工厂模式创造工厂模式是一种创建性模式也就是一种创建对象的最佳实践首先我们需要理解为什么我们需要工厂模式想象一个场景如果你要求去买一些东西板烧鸡腿 Javascript设计模式-工厂模式 最近阅读了几本设计模式方面的书籍,学习之余整理下来,方便以后的归纳和梳理 设计模式-工厂模式 创造工厂模式是一...
摘要:简单工厂模式又叫静态工厂方法模式,由一个工厂对象决定创建某一种产品对象类的实例。主要用来创建同一类对象。场景一比如体育商店卖体育器材,里面有很多体育用品,及相关介绍,当我们想买一个篮球及相关介绍时,只需要温售货员,他会帮你找到所有的东西。 简单工厂模式又叫静态工厂方法模式,由一个工厂对象决定创建某一种产品对象类的实例。主要用来创建同一类对象。场景一:比如体育商店卖体育器材,里面有很多体...
阅读 2417·2021-11-19 09:40
阅读 3588·2021-10-12 10:12
阅读 1896·2021-09-22 15:04
阅读 2910·2021-09-02 09:53
阅读 772·2019-08-29 11:03
阅读 1130·2019-08-28 18:11
阅读 1734·2019-08-23 15:28
阅读 3588·2019-08-23 15:05