前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >设计模式 - 工厂模式 - JavaScript

设计模式 - 工厂模式 - JavaScript

作者头像
心谭博客
发布2020-04-20 17:04:48
3370
发布2020-04-20 17:04:48
举报
文章被收录于专栏:YuanXinYuanXin

工厂方法模式的实质是“定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类。工厂方法让类的实例化推迟到子类中进行。”

专注前端与算法的系列干货分享,转载请声明出处:原文链接: xxoo521.com

什么是工厂模式?

工厂方法模式的实质是“定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类。工厂方法让类的实例化推迟到子类中进行。”

简单来说:就是把new对象的操作包裹一层,对外提供一个可以根据不同参数创建不同对象的函数

工厂模式的优缺点

优点显而易见,可以隐藏原始类,方便之后的代码迁移。调用者只需要记住类的代名词即可。

由于多了层封装,会造成类的数目过多,系统复杂度增加。

ES6 实现

调用者通过向工厂类传递参数,来获取对应的实体。在这个过程中,具体实体类的创建过程,由工厂类全权负责。

代码语言:javascript
复制
/**
 * 实体类:Dog、Cat
 */

class Dog {
    run() {
        console.log("狗");
    }
}

class Cat {
    run() {
        console.log("猫");
    }
}

/**
 * 工厂类:Animal
 */

class Animal {
    constructor(name) {
        name = name.toLocaleLowerCase();
        switch (name) {
            case "dog":
                return new Dog();
            case "cat":
                return new Cat();
            default:
                throw TypeError("class name wrong");
        }
    }
}

/**
 * 以下是测试代码
 */

const cat = new Animal("cat");
cat.run();
const dog = new Animal("dog");
dog.run();
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-03-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是工厂模式?
  • 工厂模式的优缺点
  • ES6 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档