JavaScript设计模式系列一:工厂模式

本篇文章给大家分享的是javascript设计模式系列:工厂模式,有感兴趣的朋友可以看一下

设计模式

设计模式(design pattern)概念:
是一套反复使用、思想成熟、经过分类和无数实战设计经验的总结。是为了代码可重用、可扩展、可解耦、更容易被人理解和保证代码可靠性。

设计模式共有23种,我今天先来了解一下工厂模式(Factory Pattern),其他的模式将会在后续的博客中陆续为大家讲解。

前言:本系列代码已上传GitHub地址https://github.com/HolyZheng/…

工厂模式

工厂模式,正像它的名字一样,可以像工厂一样生产出我们想要的东西,只要我们提供原料。在我们日常编写代码过程中,很可能,我们不知不觉中就已经使用过工厂模式。我们看一个简单的例子:

//工厂模式很基础的的一个例子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"}*/

登录后复制

在这个函数中,我可以通过传入不同的参数,创建具有不同参数值得对象。可以看到,工厂模式其实很简单。

立即学习“Java免费学习笔记(深入)”;

工厂模式(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() 方法去继承这个父类,(因为这样不会覆盖原有的原型链),然后我们再在子类中去实例化方法,不同的子类就有了不同的实例方法。
这就是工厂模式,他提高了我们代码的可重用性,降低了模块之间的耦合度。

总结

工厂模式,正像它的名字一样,可以像工厂一样生产出我们想要的东西,只要我们提供原料

工厂模式提高了我们代码的可重用性,降低了模块之间的耦合度

工厂模式主要用于创建同一类的对象的不同实例

以上就是JavaScript设计模式系列一:工厂模式的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2776326.html

(0)
上一篇 2025年3月8日 14:47:55
下一篇 2025年3月8日 14:48:52

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 用json实现ajax的数据传输方法

    这次给大家带来,用json实现ajax数据传输的注意事项有哪些,下面就是实战案例,一起来看一下。 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON…

    2025年3月8日 编程技术
    200
  • JavaScript设计模式系列二:单例模式

    本篇文章给大家分享的是javascript设计模式系列二:单例模式,有感兴趣的朋友可以看一下 单例模式 前言:本系列代码已上传到GitHub地址 https://github.com/HolyZheng/… 什么是单例模式? 单…

    编程技术 2025年3月8日
    200
  • 在实战项目中Ajax应该如何传递JSON

    这次给大家带来在实战项目中Ajax应该如何传递JSON,在实战项目中Ajax传递JSON的注意事项有哪些,下面就是实战案例,一起来看一下。 前面的话   虽然ajax全称是asynchronous javascript and XML。但目…

    2025年3月8日
    200
  • JavaScript设计模式系列三:建造者模式

    本篇文章给大家分享的是javascript设计模式系列三:建造者模式,有感兴趣的朋友可以看一下 建造者模式 建造者模式(builder pattern)比较简单,它属于创建型模式的一种,将一个复杂的对象分解成多个简单的对象来进行构建,将复杂…

    编程技术 2025年3月8日
    200
  • JavaScript设计模式系列四:原型模式

    本篇文章给大家分享的是关于javascript设计模式系列四:原型模式,有感兴趣的朋友可以看一下 本系列代码已上传到GitHub地址JavaScript设计模式demo 什么是原型模式 原型模式 (Prototype pattern):通俗…

    编程技术 2025年3月8日
    200
  • JavaScript设计模式系列五:适配器模式

    本片文章给大家分享的是javascript设计模式系列五:适配器模式,有感兴趣的朋友可以看一下 什么是适配器模式 所谓 适配器模式 就是用一个新的接口对现有的接口进行包装,处理类与API的不匹配。使用这种模式的对象又叫作包装器。比如我们有一…

    编程技术 2025年3月8日
    200
  • Ajax+json实现购物车结算

    这次给大家带来Ajax+json实现购物车结算,Ajax+json实现购物车结算的注意事项有哪些,下面就是实战案例,一起来看一下。 全选 商品 单价 数量 小计 操作 全选 删除选中产品 总价:¥0 登录后复制 body,html,ul,l…

    2025年3月8日
    200
  • JavaScript设计模式系列六:桥接模式

    本篇文章给大家分享的是javascript设计模式系列六:桥接模式 ,有感兴趣的朋友可以看一下 桥接模式 桥接(Bridge)是用于把抽象化与现实化解耦,使得二者可以独立变化,这种类型的设计模式属于结构型模式,它通过提供抽象化和现实化之间的…

    编程技术 2025年3月8日
    200
  • JavaScript设计模式七:装饰者模式

    本篇文章给大家分享了javascript设计模式七:装饰者模式,有兴趣的朋友可以看一下 装饰者模式 装饰者模式提供比继承更有弹性的替代方案。装饰者用于包装同接口的对象,用于通过重载方法的形式添加新功能,该模式可以在被装饰者的前面或后面加上自…

    编程技术 2025年3月8日
    200
  • AJAX跨域请求JSONP获取JSON数据步骤详解(附代码)

    这次给大家带来AJAX跨域请求JSONP获取JSON数据步骤详解(附代码),AJAX跨域请求JSONP获取JSON数据的注意事项有哪些,下面就是实战案例,一起来看一下。 Asynchronous JavaScript and XML (Aj…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论