常见的设计模式

构造函数模式

function Person(name,age){
      this.name = name
      this.age = age
}
Person.prototype.sayName = function(){
     console.log(this.name)
}
var people = new Person('fangfang',18)

混合模式

function Person(name,age){
    this.name = name
    this.age = age
}
Person.prototype.sayName = function(){
     console.log(this.name)
}

function Student(name,age,sex){
     Person.call(this,name,age)
    this.sex = sex
}

Student.prototype = object.create(Person.prototype)

//或者
function fn(obj){
    function F(){}
    F.prototype = obj
    return new F()
}

Student.prototype.saySex = function(){
      console.log(this.sex)
}

var lucien = new Student()

模块模式

function person(){
   var name = 'fangfang';
   function student(){
       console.log(name)
   }

   return {
        name:name,
        fn:student
   }
}
var obj = person()
obj.fn()

工厂模式

function factory(name){
    var person = {
         name:name,
         sayName:function(){
            console.log(name)
         }
    }
    return person
}
factory('cwh').name

单例模式

var people = (function(){
    var instance
    function init(name){
       return {
          name:name
       }
    }
    return {
         createPeople:function(name){
                 if(!instance){
                       instance = init(name)
                  }
                   return instance
          }
    }

}())

//只会调用一个值
people.createPeople('cwh')
people.createPeople('cwb')

发布订阅模式

var Event = (function(){    
            var obj = {};
            //obj{hello:[{handler:handler}]}
            function on(evt,handler){
                obj[evt] = obj[evt] || []
                console.log(obj)
                obj[evt].push({
                    handler:handler
                });
                console.log(obj)
            }
            function fire(evt,args){
                if (!obj[evt]) {
                    return 
                }
                for(var i=0; i<obj[evt].length; i++){
                    obj[evt][i].handler(args)
                }
            }
            function off(name){
                delete obj[name]
            }
            return {
                on:on,
                fire:fire,
                off:off
            }
})()    

        Event.on('hello',function(){
            console.log('hello')
        })
        Event.off('hello')
        Event.fire('hello')
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 各种设计模式混搭 模块模式运用场景:使用简单的导出一个对象使用var Person = (function(){ ...
    sunny519111阅读 2,905评论 0 2
  • 构造函数模式 混合模式 模块模式 工厂模式 单例模式 发布订阅模式 作业
    _达斯基阅读 3,280评论 0 0
  • 下面是iOS开发中比较常用的几种设计模式.详情如下所示: (一)代理模式 应用场景:当一个类的某些功能需要由别的类...
    梦之志阅读 2,915评论 0 0
  • 构造函数模式 混合模式(将父元素的原型链赋值给空对象F,再将空对象F赋值给子元素的原型链来实现继承同时不覆盖子元素...
    曾祥辉阅读 4,587评论 0 0
  • 构造函数模式例子: 混合模式最典型的应用就是原型的继承例子 模块模式例子 单例模式例子: 发布订阅模式 2.
    饥人谷_有点热阅读 1,765评论 0 0

友情链接更多精彩内容