美文网首页
设计模式---- 工厂方法模式

设计模式---- 工厂方法模式

作者: 简爱_cdde | 来源:发表于2018-12-11 19:15 被阅读0次

/*

            工厂方法模式:通过对产品类的抽象使其创建业务主要负责用于创建多类产品的实例

        */

        /*

            安全工厂方法就是在构造函数中进行判断,当构造函数被引用时判断构造函数的this的实例是否是这个构造函数,

            如果不是那么就将实例化好的函数return 出去;

        我们知道在js中可以自定义对象,

        我们可以通过instanceof这个方法定义来监测,这个实例是哪一个对象的;

        函数数组都可以称之为对象

        */

        var Demo = function (text) {

            if (!(this instanceof Demo)) {

                return new Demo(text)

            }

            this.text = text;

        }

        Demo.prototype.show = function () {

            console.log(this.text)

        }

        var d = Demo("爱上了快递费即可")

        d.show()

        /*  例子:*/

        //需求广告资源投放,关于计算机培训的,一批java,用绿色字体,还有一批php,用黄色字体红色背景

        //创建Java类

        var Java = function (text) {

            this.text = text;

            (function (text) {

                var div = document.createElement("div")

                div.innerHTML = text;

                div.style.color = "yellow";

                document.getElementById("java").appendChild(div)

            })(this.text)

        }

        //创建Php类

        var Php = function (text) {

            this.text = text;

            (function (text) {

                var div = document.createElement("div");

                div.innerHTML = text;

                div.style.color = "red";

                document.getElementById("php").appendChild(div)

            })(this.text)

        }

        //简单工厂方法,每次修改需要修改俩次,一个是构造函数,一个是工厂函数

        /* var Factory=function(type,text){

            switch(type){

                case 'java':

                return new Java(text);

                break;

                case 'php':

                return new Php(text);

                break;

            }

        }

        Factory("php","java学科"); */

        //工厂方法模式本意是说将实际创建对象的工作推迟到子类当中

        //简单的工厂方法是将类放在一个构造函数中,然后在工厂函数内部通过判断,将类return回去,

        //工厂方法是将构造函数写在工厂函数的原型上,

        var Factory = function (type, text) {

            // console.log(type,text)

            // return false;

            //判断当前这个方法的this是否指向了当前方法的实例

            if (this instanceof Factory) {

                console.log(this)

                var s = new this[type](text);

                return s;

            } else {

                return new Factory(type, text)

            }

        }

        Factory.prototype = {

            java: function (text) {

                (function (text) {

                    var div = document.createElement("div")

                    div.innerHTML = text;

                    div.style.color = "yellow";

                    document.getElementById("java").appendChild(div)

                })(text)

            },

            php: function (text) {

                (function (text) {

                    var div = document.createElement("div");

                    div.innerHTML = text;

                    div.style.color = "red";

                    document.getElementById("php").appendChild(div)

                })(text)

            }

        }

        Factory("php", "php学科")

相关文章

  • 2021-11-16 - 学习记录

    设计模式学习:创建型:工厂(工厂方法,抽象工厂),建造者,单例,原型 设计模式:工厂模式 简单工厂 工厂方法 抽象工厂

  • 工厂模式

    工厂模式 就是工厂---生产-->产品 在设计模式中,分为 简单工厂模式, 工厂方法模式,抽象工厂模式. 工厂模式...

  • PHP-浅谈单例模式和工厂模式

    PHP中常用的设计模式有单例模式、工厂模式(简单工厂模式、工厂方法模式和抽象工厂方法模式)、适配模式、策略模式。 ...

  • 设计模式-工厂模式

    设计模式1 设计模式2 工厂模式 工厂模式可简单的分为三类:简单工厂,工厂方法,抽象工厂 简单工厂模式 定义 简单...

  • 设计模式之工厂方法模式(创建型)

    一、模式定义 工厂方法模式:又称工厂模式,也叫虚拟构造器模式,属于构建型设计模式,工厂方法模式是在简单工厂模式上进...

  • spring 设计模式篇(前)

    设计模式俗称:套路 一、spring常见设计模式 (23种设计模式) 创建型:工厂方法模式、抽象工厂模式、建造者...

  • 设计模式系列-简单工厂模式

    JAVA设计模式系列: 单例模式 观察者模式 模板方法模式 简单工厂模式 定义 简单工厂模式又叫做静态工厂方法模式...

  • 简单工厂模式

    Android进阶之设计模式 简单工厂模式 简单工厂模式(又叫作静态工厂方法模式), 其属于创建型设计模式,但并不...

  • 设计模式之简单工厂、工厂方法、抽象工厂

    设计模式之简单工厂、工厂方法、抽象工厂 什么是设计模式? 设计模式(Design pattern)代表了最佳的实践...

  • 设计模式(六)抽象工厂模式

    导读:前文设计模式(五)工厂方法模式介绍了工厂方法模式,本篇开始介绍抽象工厂模式,继续优化工厂方法模式,更好的满足...

网友评论

      本文标题:设计模式---- 工厂方法模式

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