JavaScript设计模式(三):给我一张名片-工厂方法模式

简介: 给我一张名片-工厂方法模式

工厂方法模式(Factory Method)

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

比如解决 现有一个需求,后续可能会在增加一个类似需求,后续可能会在增加一个类似需求······,以此类推;而通过简单工厂类每次都需要添加一个类和修改工厂对象 的问题

需求问题

  • 广告投入问题:(注意每个广告的显示形式是不同的)
    1. 需求1:添加一个 JAVA 宣传广告;
    2. 需求2:添加一个 C# 宣传广告;
    3. 需求3:添加一个 UI 宣传广告;
    4. 需求n:··· ···
  • ⚠ 问题:每次接入新需求都需要去主动添加一个类并修改工厂方法内部判断

在这里插入图片描述

  • 需求1来了 ······

      // JAVA的广告
      let JAVAAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'green';
              document.getElementById('container').appendChild(div);
          }
      }
    
      /**
       * 广告工厂
       * @param {string} type 广告类型
       * @param {string} desc 广告描述
       */
      let AdFactory = function (type, desc) {
         
         
          switch (type) {
         
         
              case 'JAVA':
                  return new JAVAAd(desc);
          }
      }
    
      let javaAd = AdFactory('JAVA', '学了就秃头!!!');
      javaAd.show();
    
  • 需求2来了 ······

      // JAVA的广告
      let JAVAAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'green';
              document.getElementById('container').appendChild(div);
          }
      }
    
      // C#的广告
      let CSharpAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'red';
              document.getElementById('container').appendChild(div);
          }
      }
    
      /**
       * 广告工厂
       * @param {string} type 广告类型
       * @param {string} desc 广告描述
       */
      let AdFactory = function (type, desc) {
         
         
          switch (type) {
         
         
              case 'JAVA':
                  return new JAVAAd(desc);
              case 'C#':
                  return new CSharpAd(desc);
          }
      }
    
      let javaAd = AdFactory('JAVA', '学了就秃头!!!');
      javaAd.show();
    
      let csharpAd = AdFactory('C#', '这个语言可以开发游戏!!!');
      csharpAd.show();
    
  • 需求3来了 ······

      // JAVA的广告
      let JAVAAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'green';
              document.getElementById('container').appendChild(div);
          }
      }
    
      // C#的广告
      let CSharpAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'red';
              document.getElementById('container').appendChild(div);
          }
      }
    
      // UI的广告
      let UIAd = function (desc) {
         
         
          this.desc = desc;
          this.show = function () {
         
         
              var div = document.createElement('div');
              div.innerHTML = desc;
              div.style.color = 'blue';
              document.getElementById('container').appendChild(div);
          }
      }
    
      /**
      * 广告工厂
      * @param {string} type 广告类型
      * @param {string} desc 广告描述
      */
      let AdFactory = function (type, desc) {
         
         
          switch (type) {
         
         
              case 'JAVA':
                  return new JAVAAd(desc);
              case 'C#':
                  return new CSharpAd(desc);
              case 'UI':
                  return new UIAd(desc);
          }
      }
    
      let javaAd = AdFactory('JAVA', '学了就秃头!!!');
      javaAd.show();
    
      let csharpAd = AdFactory('C#', '这个语言可以开发游戏!!!');
      csharpAd.show();
    
      let uiAd = AdFactory('UI', '这也太酷了吧!!!');
      uiAd.show();
    
  • 需求n来了 ······

解决上述问题 (来了需求只需要添加对应的需求类和调用方法就可以了,无需修改工厂对象)

/**
 * 安全模式创建的广告工厂类 - 安全模式:检测你是否用了new进行实例
 * @param {string} type 广告类型
 * @param {string} desc 广告描述
 */
let AdFactory = function (type, desc) {
   
   
    // 判断你是否用了new
    if (this instanceof AdFactory) {
   
   
        var instance = new this[type](desc);
        return instance;
    } else {
   
   
        return new AdFactory(type, desc);
    }
}

// 广告工厂原型中设置创建所有类型数据对象的基类
AdFactory.prototype = {
   
   
    // JAVA的广告
    JAVAAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'green';
            document.getElementById('container').appendChild(div);
        }
    },
    // C#的广告
    CSharpAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'red';
            document.getElementById('container').appendChild(div);
        }
    },
    // UI的广告
    UIAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'blue';
            document.getElementById('container').appendChild(div);
        }
    }
};

let javaAd = new AdFactory('JAVAAd', '【广告需求一】学了就秃头!!!');
javaAd.show();

let csharpAd = AdFactory('CSharpAd', '【广告需求二】这个语言可以开发游戏!!!');
csharpAd.show();

let uiAd = new AdFactory('UIAd', '【广告需求三】这也太酷了吧!!!');
uiAd.show();

来了一大波需求

在这里插入图片描述

/**
 * 安全模式创建的广告工厂类
 * @param {string} type 广告类型
 * @param {string} desc 广告描述
 */
let AdFactory = function (type, desc) {
   
   
    if (this instanceof AdFactory) {
   
   
        var instance = new this[type](desc);
        return instance;
    } else {
   
   
        return new AdFactory(type, desc);
    }
}

// 广告工厂原型中设置创建所有类型数据对象的基类
AdFactory.prototype = {
   
   
    // JAVA的广告
    JAVAAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'green';
            document.getElementById('container').appendChild(div);
        }
    },
    // C#的广告
    CSharpAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'red';
            document.getElementById('container').appendChild(div);
        }
    },
    // UI的广告
    UIAd: function (desc) {
   
   
        this.desc = desc;
        this.show = function () {
   
   
            var div = document.createElement('div');
            div.innerHTML = desc;
            div.style.color = 'blue';
            document.getElementById('container').appendChild(div);
        }
    }
};

let ads = [
    {
   
   type: 'JAVAAd', desc: '【广告需求一】学了就秃头!!!'},
    {
   
   type: 'CSharpAd', desc: '【广告需求二】这个语言可以开发游戏!!!'},
    {
   
   type: 'UIAd', desc: '【广告需求三】这也太酷了吧!!!'},
];

ads.forEach(ad => {
   
   
    let adFactory = new AdFactory(ad.type, ad.desc);
    adFactory.show();
})
目录
相关文章
|
1月前
|
存储 安全 JavaScript
云计算浪潮中的网络安全之舵探索Node.js中的异步编程模式
【8月更文挑战第27天】在数字化时代的风帆下,云计算如同一片广阔的海洋,承载着企业与个人的数据梦想。然而,这片海洋并非总是风平浪静。随着网络攻击的波涛汹涌,如何确保航行的安全成为了每一个船员必须面对的挑战。本文将探索云计算环境下的网络安全策略,从云服务的本质出发,深入信息安全的核心,揭示如何在云海中找到安全的灯塔。
|
14天前
|
设计模式 算法 安全
设计模式——模板模式
模板方法模式、钩子方法、Spring源码AbstractApplicationContext类用到的模板方法
设计模式——模板模式
|
6天前
|
设计模式 数据库连接 PHP
PHP中的设计模式:如何提高代码的可维护性与扩展性在软件开发领域,PHP 是一种广泛使用的服务器端脚本语言。随着项目规模的扩大和复杂性的增加,保持代码的可维护性和可扩展性变得越来越重要。本文将探讨 PHP 中的设计模式,并通过实例展示如何应用这些模式来提高代码质量。
设计模式是经过验证的解决软件设计问题的方法。它们不是具体的代码,而是一种编码和设计经验的总结。在PHP开发中,合理地使用设计模式可以显著提高代码的可维护性、复用性和扩展性。本文将介绍几种常见的设计模式,包括单例模式、工厂模式和观察者模式,并通过具体的例子展示如何在PHP项目中应用这些模式。
|
4天前
|
设计模式 Java Spring
spring源码设计模式分析-代理设计模式(二)
spring源码设计模式分析-代理设计模式(二)
|
1天前
|
设计模式
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
这篇文章详细解释了工厂模式,包括简单工厂、工厂方法和抽象工厂三种类型。每种模式都通过代码示例展示了其应用场景和实现方法,并比较了它们之间的差异。简单工厂模式通过一个工厂类来创建各种产品;工厂方法模式通过定义一个创建对象的接口,由子类决定实例化哪个类;抽象工厂模式提供一个创建相关或依赖对象家族的接口,而不需要明确指定具体类。
设计模式-工厂模式 Factory Pattern(简单工厂、工厂方法、抽象工厂)
|
12天前
|
JavaScript 前端开发 开发者
探索Node.js中的异步编程模式
【9月更文挑战第15天】在Node.js的世界中,“一切皆异步”不仅是一句口号,更是其设计哲学的核心。本文将带你深入理解Node.js中异步编程的几种主要模式,包括经典的回调函数、强大的Promise对象、以及简洁的async/await结构。我们将通过实例代码来展示每种模式的使用方式和优缺点,帮助你更好地掌握Node.js异步编程的精髓。无论你是Node.js新手还是有一定经验的开发者,这篇文章都能给你带来新的启示和思考。让我们一起开启Node.js异步编程的探索之旅吧!
|
14天前
|
JavaScript 前端开发 中间件
深入浅出Node.js中间件模式
【9月更文挑战第13天】本文将带你领略Node.js中间件模式的魅力,从概念到实战,一步步揭示如何利用这一强大工具简化和增强你的Web应用。我们将通过实际代码示例,展示中间件如何在不修改原有代码的情况下,为请求处理流程添加功能层。无论你是前端还是后端开发者,这篇文章都将为你打开一扇通往更高效、更可维护代码的大门。
|
2天前
|
设计模式 Java
Java设计模式-工厂方法模式(4)
Java设计模式-工厂方法模式(4)
|
25天前
|
JavaScript 前端开发
JavaScript基础知识-使用工厂方法创建对象
本文介绍了JavaScript中使用工厂方法来创建对象的基础知识。
24 0
JavaScript基础知识-使用工厂方法创建对象
|
1月前
|
设计模式 JavaScript 前端开发
Vue.js组件设计模式:构建可复用组件库
在Vue.js中,构建可复用组件库是提升代码质量和维护性的核心策略。采用单文件组件(SFC),定义props及默认值,利用自定义事件和插槽进行灵活通信,结合Vuex或Pinia的状态管理,以及高阶组件技术,可以增强组件的功能性和灵活性。通过合理的抽象封装、考虑组件的可配置性和扩展性,并辅以详尽的文档和充分的测试,能够打造出既高效又可靠的组件库。此外,采用懒加载、按需导入技术优化性能,制定设计系统和风格指南确保一致性,配合版本控制、CI/CD流程和代码审查机制,最终形成一个高品质、易维护且具有良好社区支持的组件库。
53 7