js设计模式 --- 工厂模式

简单工厂

由一个工厂对象决定创建某一种产品对象类的实例。主要用来创建同一类对象。简单来讲,就是根据原料生成不同的产品

优点:只需要一个正确的参数就可以获取到所需要的对象,而无需知道其创建的具体细节

缺点:函数内包含了所有对象的创建逻辑和判断逻辑的代码,对象数量过多时难以维护

适用于:创建的对象数量较少,对象的创建逻辑不复杂

案例:后台的权限管理系统

javascript 复制代码
    function User(role, pages) {
        this.role = role;
        this.pages = pages;
    }
    var a = new User("superAdmin",["home","user-manage","right-manage","news-manage"])
    var b = new User("admin",["home","user-manage","news-manage"])
    var c = new User("editor",["home","news-manage"])
    //a.role === current.role

改进:

添加生成User对象的函数

javascript 复制代码
    function UserFactory(role) {
        function User(role, pages) {
            this.role = role;
            this.pages = pages;
        }
        switch (role) {
            case "superAdmin":
                return new User("superAdmin", ["home", "user-manage", "right-manage", "news-manage"])
            case "admin":
                return new User("admin", ["home", "user-manage", "news-manage"])
            case "editor":
                return new User("editor", ["home", "news-manage"])
            default:
                return new User("guest", ["home"])
        }
    }
    var user = UserFactory("editor")

    // es6写法
    class User {
        constructor(role, pages) {
            this.role = role;
            this.pages = pages;
        }
        // 生成User对象的函数。简单工厂:根据原料生成不同的产品。
        static UserFactory(role) {
            switch (role) {
                case "superAdmin":
                    return new User("superAdmin", ["home", "user-manage", "right-manage", "news-manage"])
                case "admin":
                    return new User("admin", ["home", "user-manage", "news-manage"])
                case "editor":
                    return new User("editor", ["home", "news-manage"])
                default:
                    return new User("guest", ["home"])
            }
        }
    }

    var user = User.UserFactory("editor")

抽象工厂

抽象工厂模式并不直接生成实例,而是用于对产品类簇的创建。在简单工厂基础上进一步解耦,对扩展开放,对修改关闭。

通俗一点:抽象工厂不生产水,只是大自然的搬运工。

适用于:大型应用,对象逻辑复杂

上述案例扩展:不同的角色有不同的页面渲染逻辑

图示:

代码:

javascript 复制代码
//抽象产品类
class User{
    constructor(name,role,pages){
        this.name = name
        this.role = role
        this.pages = pages
    }
    welcome(){
        console.log("欢迎回来",this.name)
    }
    dataShow(){
        //abstract
        throw new Error("抽象方法需要被实现")
    }
}
class SuperAdmin extends User{
    constructor(name){
        super(name,"superAdmin",["home","user-manage","right-manage","news-manage"])
    }
    //重写dataShow
    dataShow(){
        console.log("superAdmin-dataShow")
    }
    // 特有方法
    addRight(){

    }
    addUser(){

    }
}
class Admin extends User{
    constructor(name){
        super(name,"admin",["home","user-manage","news-manage"])
    }
    //重写dataShow
    dataShow(){
        console.log("admin-dataShow")
    }
    // 特有方法
    addUser(){
        
    }
}
    class Editor extends User{
    constructor(name){
        super(name,"editor",["home","news-manage"])
    }
    //重写dataShow
    dataShow(){
        console.log("editor-dataShow")
    }
}

// 抽象工厂的简化形式,这里直接返回类
function getAbstractUserFactory(role){
    switch(role){
        case "superAdmin":
            return SuperAdmin
        case "admin":
            return Admin
        case "editor":
            return Editor
        default:
            throw new Error("参数错误")
    }
}

let UserClass = getAbstractUserFactory("superAdmin")
console.log(UserClass)
let user = new UserClass("mill")
console.log(user)

抽象工厂的核心目标 是封装产品创建,返回实例 是标准做法,返回是前端常见的简化形式;

无论返回类还是实例,核心都是让客户端不直接依赖具体产品类,符合抽象工厂 "解耦创建逻辑" 的核心思想。

相关推荐
乐观的山里娃22 分钟前
【设计模式 13】命令:覆水能收
设计模式
乐观的山里娃1 小时前
【设计模式 11】建造者:配置像天书
设计模式
看山是山_Lau21 小时前
建造者模式:复杂对象如何一步步构建
设计模式·建造者模式
霸道流氓气质1 天前
业务链路追踪日志设计模式 — 从原理到实践
设计模式
nnsix2 天前
设计模式 - 建造者模式 笔记
笔记·设计模式·建造者模式
cui17875682 天前
矩阵拼团 + 复购拼团:新零售最稳的复购模式,规则简单
大数据·人工智能·设计模式·零售
百珏2 天前
[灰度发布]:全链路透传组件:APM、自研方案与 Java Agent 的实现取舍
后端·设计模式·架构
likerhood2 天前
设计模式 · 享元模式(Flyweight Pattern)java
java·设计模式·享元模式
AI大法师2 天前
从 Adobe 焕新看品牌系统升级:Logo、主色、字体与产品体验如何重新对齐
大数据·人工智能·adobe·设计模式
贵慜_Derek2 天前
《从零实现 Agent 系统》连载 03|控制循环:感知—决策—行动—反思
人工智能·设计模式·架构