手写发布订阅加单例模式

发布订阅

发布订阅者模式是什么?

老刘去买房,去到别墅区,他可以定很多套房子;去到平房区又可以定很多套房子(on)。交完首付后就可以安心了(emit)。如果不想买就不交钱退订(off)。售楼部有汤臣亿品,每人只能买一套房子(once)。

现在我们的任务就是帮老刘完成上面的步骤

拿上钱包

我们要帮老刘买房,那老刘拿什么买呢?当然是钱包了。 让我们帮老刘带上钱包:

js 复制代码
class Eventmitter{
    constructor() {
        this.event = {}
    }
}

先去订房

不同的房源可以买很多栋,那就好办了,老刘想买什么房就买什么房,想在哪个房源买就到哪个房源买。有钱就是任性。

js 复制代码
on(type,cb){
        if(!this.event[type]){
            this.event[type] = [cb]
        }else{
            this.event[type].push(cb)
        }
        
    }

付上首付

既然定了房那肯定帮老刘把首付搞定啊,让我们帮老刘把首付付了。

js 复制代码
    emit(type,arg){
        if(!this.event[type]){
            return
        }
        this.event[type].forEach(cb=>{
            cb(...arg)
        })
    }

退款

老刘真是的,才交完首付就想要退,没办法,谁叫老刘才是金主爸爸,那就退咯。

js 复制代码
off(type,cb){
        const index = this.event[type]
        const handles =index && index.indexOf(cb)
        if(handles !== -1){
            index.splice(handles,1)
        }
    }

买限定

原来老刘看上了一栋限定的房子,还好金主是想花更多的钱,啊呸,是想要更好的生活。

js 复制代码
once(type,cb){
        if(this.event[type] && this.event[type].indexOf(cb) !== -1){
            return
        }
        this.on(type,cb)
    }

最后参观一下老刘买的房子怎么样吧。

js 复制代码
const emiter = new Eventmitter()

function foo(){
    console.log('去买房');
}

emiter.on('sell',foo)
emiter.emit('sell')

单例模式

单例模式什么意思?你只能有一个老婆,这是法律规定的。平时你这一个女朋友,哪一个女朋友就不说你了。可是老婆只能有一个。

那单例模式可以用来干什么呢?比如弹出框、验证登陆等等。

单例模式得创建一个静态函数方法,防止其他对象发现

js 复制代码
class Person {
    constructor(name) {
      this.name = name
    }
    static getInfo(name) {
      if (!Person.instance) {
        Person.instance = new Person(name)
      }
      return Person.instance
    }
  }
  
  let p1 = Person.getInfo('李总')
  let p2 = Person.getInfo('李总')
  
  console.log(p1 == p2);

再来一个闭包的实现:

js 复制代码
function Storage() {
    this.name = '张三'
  }
  
  const Helper = (function() {
    let instance = null
    return function() {
      if (!instance) {
        instance = new Storage()
      }
      return instance
    }
  })()
  
  let p1 = new Helper()  // {name: '张三'}
  let p2 = new Helper() 
  console.log(p1 === p2); 

使用立即执行函数是为了只创建一个instance。后面再调用也不会再创建instance,保证了唯一性。

这些是不是了解起来特别简单呢。

相关推荐
api工厂2 分钟前
ZCode 3.0 版本搭配GLM-5.2能力测试
前端·人工智能·ai
小小小小宇5 分钟前
单点登录(二)
前端
Frank学习路上17 分钟前
【C++】面试:STL容器与算法
c++·算法·面试
阿猫的故乡21 分钟前
Vue + Axios 从入门到封装:拦截器、错误处理、请求取消、接口管理全搞定
前端·javascript·vue.js
良逍Ai出海36 分钟前
免费模板搭完独立站后,我用 Codex + Figma 做了自己的页面设计
前端·人工智能·figma
纽格立科技40 分钟前
DRM 发射端链路图(下)
前端·人工智能·车载系统·信息与通信·传媒
代码小库43 分钟前
【2026前端转 AI 全栈指南】第 2 章(下):NestJS 项目创建 · MongoDB 配置 · 项目启动与调试
前端·数据库·mongodb
于指尖飞舞43 分钟前
java后端面试题(常用集合极简)
java·开发语言·面试
之歆1 小时前
Promise 基础技术深度解析:从回调地狱到链式调用
前端·okhttp·promise
甲维斯1 小时前
国产版“Codex”初体验,智谱ZCode很强啊!
前端·人工智能·ai编程