当前位置:首页 > 科技  > 软件

PixiJS 源码解读:Runner 事件通知类

来源: 责编: 时间:2023-10-13 14:34:39 182观看
导读大家好,我是前端西瓜哥。PixiJS 的 Runner 类是高性能的事件通知类。其实就是一个简易的发布订阅库。发布订阅库,我们比较熟悉的就是 Nodejs 的 EventEmitter。不过这个 Runner 的逻辑稍微有点特殊,后面会说它怎么特殊。

SbO28资讯网——每日最新资讯28at.com

大家好,我是前端西瓜哥。SbO28资讯网——每日最新资讯28at.com

PixiJS 的 Runner 类是高性能的事件通知类。其实就是一个简易的发布订阅库。SbO28资讯网——每日最新资讯28at.com

发布订阅库,我们比较熟悉的就是 Nodejs 的 EventEmitter。SbO28资讯网——每日最新资讯28at.com

不过这个 Runner 的逻辑稍微有点特殊,后面会说它怎么特殊。SbO28资讯网——每日最新资讯28at.com

使用示例

import { Runner } from "@pixi/runner";const loadedRunner = new Runner("loaded");const listener = {  loaded(n1: number, n2: number) {    console.log("前端西瓜哥", n1, n2);  }};loadedRunner.add(listener);loadedRunner.emit(1, 2); // 输出:前端西瓜哥 1 2

首先通过 new Runner(name) 创建一个 Runner 实例,这里需要传入一个字符串类型的 name。SbO28资讯网——每日最新资讯28at.com

之后通过 runner.add 方法添加一个监听器对象 listener。SbO28资讯网——每日最新资讯28at.com

最后通过 runner.emit 方法触发事件,之前绑定的监听器的 listener[name]  方法会被执行。SbO28资讯网——每日最新资讯28at.com

和我们熟悉的 Nodejs 的 EventEmitter 不一样,有一些特别的点:SbO28资讯网——每日最新资讯28at.com

  • 一个 Runner 只能绑定一个事件,不像 EventEmitter 的 on 方法,还能多指定一个事件名。
  • 绑定的监听器是一个对象,并会在触发事件时调用 Runner 初始化时设置的 name 对应的函数。这样做的优点是监听器执行时 this 不会丢失。EventEmitter 绑定的直接就是一个函数。

然后它和 EventEmitter 一样,是类型不安全的:emit 传的参数并没有限定。SbO28资讯网——每日最新资讯28at.com

源码解读

构造函数

首先是构造函数。SbO28资讯网——每日最新资讯28at.com

export class Runner {  public items: any[];  private _name: string;  private _aliasCount: number;  constructor(name: string) {    this.items = [];    this._name = name;    this._aliasCount = 0;  }  // ...}

简单的初始化操作,这个 name 我们要保存下来,之后我们执行监听器对象,需要这个 name 作为 key 去找到方法去执行。SbO28资讯网——每日最新资讯28at.com

items 是保存监听器对象的数组。SbO28资讯网——每日最新资讯28at.com

_aliasCount 是一个标识,标识是否在 emit(触发事件)阶段,用于防止 emit 时改变了 items,导致不可预期的行为。SbO28资讯网——每日最新资讯28at.com

添加监听器

然后是 add 方法,用于添加监听器。SbO28资讯网——每日最新资讯28at.com

public add(item: unknown): this {  if ((item as any)[this._name]) {    this.ensureNonAliasedItems();    this.remove(item); // 如果存在,先删除    this.items.push(item); // 添加的末尾  }  return this;}

监听器对象必须有对应的 key 才能被添加进去。SbO28资讯网——每日最新资讯28at.com

为了保证 this.items 不出现多个相同的对象,会将其删除。然后把监听器对象放到 this.items 末尾。SbO28资讯网——每日最新资讯28at.com

返回 this,是为了实现链式调用。SbO28资讯网——每日最新资讯28at.com

this.ensureNonAliasedItems() 方法用于处理一些特殊 case。SbO28资讯网——每日最新资讯28at.com

比如在 emit 阶段发生了 add 操作,PixiJS 会防止其在本轮 emit 被执行,为此会拷贝一份新的 items。SbO28资讯网——每日最新资讯28at.com

private ensureNonAliasedItems(): void {  if (this._aliasCount > 0 && this.items.length > 1) {    this._aliasCount = 0;    this.items = this.items.slice(0);  }}

事件触发

emit 会触发事件,别名有 dispatch、run。SbO28资讯网——每日最新资讯28at.com

public emit(  a0?: unknown,  a1?: unknown,  a2?: unknown,  a3?: unknown,  a4?: unknown,  a5?: unknown,  a6?: unknown,  a7?: unknown): this {  if (arguments.length > 8) {    throw new Error('max arguments reached');  }  const { name, items } = this;  this._aliasCount++;  for (let i = 0, len = items.length; i < len; i++) {    items[i][name](a0, a1, a2, a3, a4, a5, a6, a7);  }  if (items === this.items) {    this._aliasCount--;  }  return this;}

核心逻辑:遍历 this.items 数组,顺序执行监听器的 key 为 this.name 的方法。SbO28资讯网——每日最新资讯28at.com

删除监听器

remove,删除监听器。SbO28资讯网——每日最新资讯28at.com

public remove(item: unknown): this {  const index = this.items.indexOf(item);  if (index !== -1) {    this.ensureNonAliasedItems();    this.items.splice(index, 1);  }  return this;}

其他方法

contains:查看指定对象是已经是被绑定为监听器。SbO28资讯网——每日最新资讯28at.com

public contains(item: unknown): boolean {  return this.items.includes(item);}

removeAll:删除所有监听器.SbO28资讯网——每日最新资讯28at.com

public removeAll(): this {  this.ensureNonAliasedItems();  this.items.length = 0;  return this;}

destory:销毁。销毁后就不能再用了,否则会报错。SbO28资讯网——每日最新资讯28at.com

public destroy(): void {  this.removeAll();  this.items = null;  this._name = null;}

empty,是一个 getter,判断是否存在监听器集合。PixiJS 确实喜欢用 getterSbO28资讯网——每日最新资讯28at.com

public get empty(): boolean {  return this.items.length === 0;}

结尾

通常我们会在 PixiJS 的类中看到名为 disposeRunner 的成员属性,说明这个类会通过事件订阅的方式和其他模块通信。SbO28资讯网——每日最新资讯28at.com

发布订阅库我实在是分析得够多了,基本的套路就 3 个:把监听器函数放到有序表中,触发事件时顺序调用,支持删除监听器(3 种风格)。SbO28资讯网——每日最新资讯28at.com

PixiJS 的 Runner 功能并不多,其中特殊的调用逻辑(调用监听器的特定 key)显然是用于 PixiJS 内部模块的风格。SbO28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-13495-0.htmlPixiJS 源码解读:Runner 事件通知类

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 如何更优雅的编程?面向接口编程四大法宝!

下一篇: 深入了解桶排序:原理、性能分析与 Java 实现

标签:
  • 热门焦点
  • 三言两语说透设计模式的艺术-简单工厂模式

    三言两语说透设计模式的艺术-简单工厂模式

    一、写在前面工厂模式是最常见的一种创建型设计模式,通常说的工厂模式指的是工厂方法模式,是使用频率最高的工厂模式。简单工厂模式又称为静态工厂方法模式,不属于GoF 23种设计
  • K8S | Service服务发现

    K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 一文搞定Java NIO,以及各种奇葩流

    一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • 2023年,我眼中的字节跳动

    2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的&ldquo;头腾
  • 花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    来源:极点商业作者:杨铭在淘宝购买珠宝玉石后,因为保证金不够赔付,店铺关闭,退货退款难、维权无门的比比皆是。&ldquo;提供相关产品鉴定证书,支持全国复检,可以30天无理由退换货。&
  • 2299元起!iQOO Pad明晚首销:性能最强天玑平板

    2299元起!iQOO Pad明晚首销:性能最强天玑平板

    5月23日,iQOO如期举行了新品发布会,除了首发安卓最强旗舰处理器的iQOO Neo8系列新机外,还在发布会上推出了旗下首款平板电脑——iQOO Pad,其最大的卖点
  • Windows 11发布,微软一改往常对老机型开放的态度

    Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
  • DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    10月30日,据韩国媒体消息,自今年年初以来一直在上涨的 DRAM 存储器的交易价格仅在本月就下跌了近 10%,此次是全年首次降价,而NAND 闪存本月价格与上月持平。市
  • 苹果MacBook Pro 2021测试:仍不支持平滑滚动

    苹果MacBook Pro 2021测试:仍不支持平滑滚动

    据10月30日9to5 Mac 消息报道,苹果新的 14 英寸和 16 英寸 MacBook Pro 2021 上市后获得了不错的评价,亮点包括行业领先的性能,令人印象深刻的电池续航,精美丰
Top
Baidu
map