美文网首页
设计模式

设计模式

作者: 汤初景 | 来源:发表于2018-05-29 22:42 被阅读0次
  • 构造函数模式
function Person(name,age){
  this.name = name
  this.age = age
}
Person.prototype.sayName = function(){
  return this.name
}

let student = new Person('tyy',25)
  • 工厂模式
function craetePerson(name){
  var person = {
    name: name,
    sayName: function(){
      console.log(this.name)
    }
  }
  return person
}
craetePerson('tyy')
  • 单例模式
var People = (function(){
  var instance
  function init(name){
    return {
      name: name
    }
  }
  return {
    craetePeople: function(name){
      if(!instance){
        instance = init(name)
      }
      return instance
    }
  }
}())
People.craetePeople('tyy') //{name: 'tyy'}
People.craetePeople('yyt') //{name: 'tyy'}
单例模式内部有次判定,当第二次创建时不会建立新的引用
  • 模块模式
var Person = (function(){
  var name = 'tyy'
  function sayName(){
    console.log(name)
  }
  return {
    name: name,
    sayName: sayName
  }
})()
  • 订阅发布模式
var EventCenter = (function () {
  var events = {};
  //('hello',function(){})
  function on(evt, handler) {
    //判断events里有没有events['hello'],如果没有events['hello']=[]
    events[evt] = events[evt] || [];
    // events['hello']=[{ handler: handler}]
    events[evt].push({
      handler: handler
    });
  }

  function fire(evt, args) {
    if (!events[evt]) {
      return;
      //如果不存在,跳出
    }
    for (var i = 0; i < events[evt].length; i++) {
      events[evt][i].handler(args);
      // 遍历数组,执行handler
    }
  }
  // 取消订阅
  function off(evt){
     delete events[evt]
  }

  return {
    on: on,
    fire: fire,
    off: off   // 取消订阅
  }
})();

EventCenter.on('hello', function () { console.log('hello') })

EventCenter.fire('hello')

  • 混合模式(待续...)

相关文章

  • 设计模式

    常用的设计模式有,单例设计模式、观察者设计模式、工厂设计模式、装饰设计模式、代理设计模式,模板设计模式等等。 单例...

  • 设计模式笔记汇总

    目录 设计原则 “依赖倒置”原则 未完待续... 设计模式 设计模式——策略模式 设计模式——装饰者模式 设计模式...

  • 设计模式

    《C#设计模式》 《C#设计模式》-设计模式概述 《C#设计模式》-面向对象设计原则 《C#设计模式》-单例模式 ...

  • 浅谈JS的一些设计模式

    @(书籍阅读)[JavaScript, 设计模式] 常见设计模式 设计模式简介 设计模式概念解读 设计模式的发展与...

  • 前端设计模式

    JS设计模式一:工厂模式jS设计模式二:单例模式JS设计模式三:模块模式JS设计模式四:代理模式JS设计模式五:职...

  • 设计模式之工厂模式

    设计模式之工厂模式 标签(空格分隔): 设计模式 工厂模式 设计模式的感念 设计模式的应用 工厂设计模式的产生 工...

  • JavaJavascript基础进阶(十七)JS中常用的设计模式

    单利设计模式、构造原型设计模式、发布订阅设计模式、promise设计模式 单利模式 构造原型设计模式 最贴近OOP...

  • 设计模式 - 目录

    设计模式01 - 单例模式 设计模式02 - 工厂模式 设计模式03 - 建造者模式 设计模式04 - 适配器模式...

  • 第1章 设计模式概述

    一、设计模式的概念 二、设计模式的历史 三、设计模式的要素 四、设计模式的分类 ■ 创建型设计模式 ■ 结构型设计...

  • iOS设计模式(3)适配器模式

    设计模式系列文章 《iOS设计模式(1)简单工厂模式》《iOS设计模式(2)工厂模式》《iOS设计模式(4)抽象工...

网友评论

      本文标题:设计模式

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