手写发布订阅加单例模式

发布订阅

发布订阅者模式是什么?

老刘去买房,去到别墅区,他可以定很多套房子;去到平房区又可以定很多套房子(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,保证了唯一性。

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

相关推荐
Deng9452013147 分钟前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
威迪斯特10 分钟前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
wuhen_n37 分钟前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端38 分钟前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛41 分钟前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦43 分钟前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU72903544 分钟前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
-凌凌漆-1 小时前
【npm】npm的-D选项介绍
前端·npm·node.js
鹿心肺语1 小时前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
海石2 小时前
去到比北方更北的地方—2025年终总结
前端·ai编程·年终总结