美文网首页
工厂模式 之一 简单工厂模式

工厂模式 之一 简单工厂模式

作者: helloyoucan | 来源:发表于2019-04-23 20:17 被阅读0次

简单工厂模式:创建单一对象

又叫静态工厂方法,由一个工厂对象觉得创建某一种产品对象类的实例。主要用来创建同一类对象。

需求1:提示用户,‘用户名不能多于16个字母或数字’

const LoginAlert = function (text) {
    this.content = text
}
LoginAlert.prototype.show = function(){
    //显示警示框
    console.log('显示警示框:',this.content)
}
const userNameAlert = new LoginAlert('用户名不能多于16个字母或数字')
userNameAlert.show()

需求2:用户输入的密码不正确时,提示用户‘输入的密码不正确’

const passwordAlert = new LoginAlert('输入的密码不正确')
passwordAlert.show()

需求3:提示用户名不存在,并在警示框显示一个注册按钮

const loginConfirm = function(text){
    this.content = text
}
loginConfirm.prototype.show = function(){
    //显示有注册按钮的警示框
    console.log('显示有注册按钮的警示框:',this.content)
}
const loginFailCongirm = new loginConfirm('您的用户名不存在,请重新输入')
loginFailCongirm.show()

需求4:登陆成功后,显示一个自定义提示框,有确定取消按钮,有欢迎语

const loginPrompt = function(){
    this.content = text
}
loginPrompt.prototype.show = function(){
    //显示有欢迎语的提示框
    console.log('显示有欢迎语的提示框:',this.content)
}

问题所在:当把这些功能类提供给其它人使用时,每次都需要找到对应的类,比较麻烦
优化方法:应用简单工厂模式,将这些类封装到一个函数里面,使用者只需要知道这个函数,和函数需要传递的参数即可,不需要知道所有的类

优化1:简单工厂模式

const PopFactory = function(name){
    switch(name){
        case 'alert':return new LoginAlert()
        case 'confirm':return new loginConfirm()
        case 'prompt':return new loginPrompt()
    }
}

问题所在:LoginAlert,loginConfirm,loginPrompt这三个类很多地方是相同的,可以抽象提出出来供应
优化方法:使用简单工厂模式实现这几个类

优化2:工厂模式

function createPop(type,text){
    //创建一个对象,并对对象扩展属性和方法
    const o = new Object()
    o.content = text
    o.show = function(){
        //显示方法
    }
    switch(type){
        case 'alert': 
        // 警示框差异部分
        black
        case 'prompt': 
        // 警示框差异部分
        black
        case 'confirm': 
        // 确认框差异部分
        black
    }
    //将对象返回
    return o
}
// 创建警示框
const userNameAlert2 = createPop('alert','用户名不能多于16个字母或数字')

相关文章

  • Java设计模式之简单工厂模式

    简单工厂模式不属于23种 GoF(Gang of Four)设计模式之一。 定义 简单工厂模式(又叫作静态方法工厂...

  • 工厂模式

    工厂模式包含三种模式:简单工厂模式、工厂方法模式和抽象工厂模式。 简单工厂模式 定义简单工厂模式:由一个工厂类根据...

  • Java设计模式——工厂模式

    工厂模式简单工厂模式工厂方法模式抽象工厂模式 1.简单工厂模式 1.基本介绍1)简单工厂模式也叫静态工厂模式,是属...

  • [Android]三种工厂模式总结。

    Android中,工厂模式分为三种:简单工厂模式、工厂方法模式、抽象工厂模式。 一.简单工厂模式。 定义:简单工厂...

  • 找女朋友之简单工厂模式,工厂模式,抽象工厂模式

    找女朋友之简单工厂模式,工厂模式,抽象工厂模式 找女朋友之简单工厂模式,工厂模式,抽象工厂模式

  • 简单工厂模式

    工厂方法模式(Factory Pattern)是创建型设计模式之一。 一、定义 简单工厂模式又称为静态方法工厂模式...

  • 工厂模式

    工厂模式细分三种:简单工厂模式、工厂模式、抽象工厂模式。 工厂模式相当于抽象了简单工厂模式的工厂类,而抽象工厂模式...

  • iOS设计模式-工厂模式

    工厂模式分为简单工厂模式,工厂模式、抽象工厂模式三类。 简单工厂模式 1. 定义 简单工厂模式并不是常用的设计模式...

  • Android设计模式:工厂设计模式

    目录 简单工厂模式工厂方法模式抽象工厂模式 简单工厂模式 简单工厂模式是所有工厂模式的基础,不属于23种设计模式范...

  • 设计模式2-工厂模式

    工厂模式分为简单工厂模式、工厂方法模式和抽象工厂模式 简单工厂模式 简单工厂模式,就是建立一个工厂类,对实现了同一...

网友评论

      本文标题:工厂模式 之一 简单工厂模式

      本文链接:https://www.haomeiwen.com/subject/ceuegqtx.html