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();
})
目录
相关文章
|
5天前
|
设计模式 前端开发 搜索推荐
前端必须掌握的设计模式——模板模式
模板模式(Template Pattern)是一种行为型设计模式,父类定义固定流程和步骤顺序,子类通过继承并重写特定方法实现具体步骤。适用于具有固定结构或流程的场景,如组装汽车、包装礼物等。举例来说,公司年会节目征集时,蜘蛛侠定义了歌曲的四个步骤:前奏、主歌、副歌、结尾。金刚狼和绿巨人根据此模板设计各自的表演内容。通过抽象类定义通用逻辑,子类实现个性化行为,从而减少重复代码。模板模式还支持钩子方法,允许跳过某些步骤,增加灵活性。
|
2月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
4月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
2月前
|
设计模式 开发者 Python
Python编程中的设计模式:工厂方法模式###
本文深入浅出地探讨了Python编程中的一种重要设计模式——工厂方法模式。通过具体案例和代码示例,我们将了解工厂方法模式的定义、应用场景、实现步骤以及其优势与潜在缺点。无论你是Python新手还是有经验的开发者,都能从本文中获得关于如何在实际项目中有效应用工厂方法模式的启发。 ###
|
25天前
Next.js 实战 (三):优雅的实现暗黑主题模式
这篇文章介绍了在Next.js中实现暗黑模式的具体步骤。首先,需要安装next-themes库。然后,在/components/ThemeProvider/index.tsx文件中新增ThemeProvider组件,并在/app/layout.tsx文件中注入该组件。如果想要加入过渡动画,可以修改代码实现主题切换时的动画效果。最后,需要在需要的位置引入ThemeModeButton组件,实现暗黑模式的切换。
|
2月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
40 2
|
2月前
|
设计模式 安全 Java
Kotlin - 改良设计模式 - 构建者模式
Kotlin - 改良设计模式 - 构建者模式
|
2月前
|
前端开发 JavaScript UED
探索JavaScript的异步编程模式
【10月更文挑战第40天】在JavaScript的世界里,异步编程是一道不可或缺的风景线。它允许我们在等待慢速操作(如网络请求)完成时继续执行其他任务,极大地提高了程序的性能和用户体验。本文将深入浅出地探讨Promise、async/await等异步编程技术,通过生动的比喻和实际代码示例,带你领略JavaScript异步编程的魅力所在。
33 1
|
2月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
46 1
|
3月前
|
前端开发 JavaScript UED
探索JavaScript中的异步编程模式
【10月更文挑战第21天】在数字时代的浪潮中,JavaScript作为一门动态的、解释型的编程语言,以其卓越的灵活性和强大的功能在Web开发领域扮演着举足轻重的角色。本篇文章旨在深入探讨JavaScript中的异步编程模式,揭示其背后的原理和实践方法。通过分析回调函数、Promise对象以及async/await语法糖等关键技术点,我们将一同揭开JavaScript异步编程的神秘面纱,领略其带来的非阻塞I/O操作的魅力。让我们跟随代码的步伐,开启一场关于时间、性能与用户体验的奇妙之旅。