fly63前端网

www.fly63.com

首页文章资源工具教程 栏目
  • 关于我们
  • 网站投稿
  • 赞助一下
搜索

在线工具_工作生活好帮手

打造各种简单、易用、便捷的在线工具,网友无需注册和下载安装即可使用

点击查看

关闭

提交网站

Pubsub.js
分享
复制链接
新浪微博
QQ 好友

扫一扫分享

GitHub:https://github.com/mroderick/PubSubJS
网站描述:一个用 JavaScript 编写的基于主题的 发布/订阅库

PubSubJS 是一个用 JavaScript 编写的基于主题的 发布/订阅库。 

PubSubJS 有同步解耦,所以主题是异步发布的。这有助于使您的程序保持可预测性,因为在消费者处理主题时,主题的发起者不会被阻止。 对于喜欢冒险的人,PubSubJS 还支持同步主题发布。这可以在某些环境(浏览器,不是全部)中提供加速,但也可能导致一些非常难以推理的程序,其中一个主题触发同一执行链中另一个主题的发布。


主要特点

  • 无依赖
  • 同步解耦
  • ES3 兼容。PubSubJS 应该能够在任何可以执行 JavaScript 的地方运行。浏览器、服务器、电子书阅读器、旧手机、游戏机。
  • AMD / CommonJS 模块支持
  • 不修改订阅者(jquery 自定义事件修改订阅者)
  • 易于理解和使用(感谢同步解耦)
  • 小(ish),小于 1kb 压缩和压缩


基本使用

首先,让我们来看看如何使用 pubsub.js 进行消息的发送与接收。首先,我们需要引入库:

import PubSub from "pubsub-js";

然后,在需要发送消息的地方,我们可以使用 publish 方法:

// 发布一个名为 'testEvent' 的事件,并带上数据
let data = { name: 'John Doe' };
PubSub.publish('testEvent', data);

而在需要接收消息的地方,我们需要先使用 subscribe 方法进行订阅:

// 订阅名为 'testEvent' 的事件
let subscription = PubSub.subscribe('testEvent', function(message, data) {
console.log("Received data:", data.name);
});
// 当不再需要接收消息时,记得取消订阅
PubSub.unsubscribe(subscription);

以上就是一个简单的消息订阅发布流程。


一些使用场景

比如:状态。

// 可以外部变更组件内状态
pubsub.publish(STATE_UPDATED_EVENT, newState);

// 在其他组件中订阅该事件以获得新状态
pubsub.subscribe(STATE_UPDATED_EVENT, (newState) => {
this.setState(newState);
});

事务处理。

// 当异步操作完成时发布事件

function subscribeTransaction() {
var subscription = PubSub.subscribe("transaction_start", async function(message, data) {
try {
// 处理事务...
await someAsyncOperation();
await someOtherAsyncOperation();
resolve(true);
} catch(e) {
reject(e);
}
});

可以设置主题。

import react, { useState, useEffect } from 'react';
import PubSub from 'pubsub-js';

function App() {
const [theme, setTheme] = useState('default');

const handleThemeChange = (nextTheme) => {
setTheme(nextTheme);
};

useEffect(() => {
const subscription = PubSub.subscribe('theme-change', handleThemeChange);
return () => {
PubSub.unsubscribe(subscription);
};
}, []);

return (
<div>
<h1>Current theme: {theme}</h1>

{/* 主题切换按钮 */}
<button onClick={() => PubSub.publish('theme-change', 'dark')}>
Switch to dark mode
</button>

{/* 这个组件会随着主题改变而变 */}
<ThemedFunctionComponent theme={theme} />
</div>
);
}

function ThemedFunctionComponent({ theme }) {
useEffect(() => {
console.log('Theme changed to:', theme);
}, [theme]);

return (
<div style={{ color: theme === 'dark' ? '#fff' : '#000' }}>
This is the themed component.
</div>
);
}

export default App;

React 的小伙伴还可以封装一个自定义 Hooks 来更简洁的使用它。


订阅完之后,别忘了取消订阅。

取消特定订阅

var mySubscriber = function (msg, data) {
console.log(msg, data);
};

var token = PubSub.subscribe('MY TOPIC', mySubscriber);

PubSub.unsubscribe(token);

取消某个函数的所有订阅

var mySubscriber = function(msg, data) {
console.log(msg, data);
};

PubSub.unsubscribe(mySubscriber);

取消某个主题的订阅

PubSub.subscribe('a', myFunc1);
PubSub.subscribe('a.b', myFunc2);
PubSub.subscribe('a.b.c', myFunc3);

PubSub.unsubscribe('a.b');
// 'a.b'和'a.b.c' 会被取消订阅
// ` a `的通知仍然会被发布

清楚所有订阅

PubSub.clearAllSubscriptions();
// 所有订阅都被删除

订阅计数

PubSub.countSubscriptions('token');

PubSub.js 通过发布/订阅模式实现实现组件间的解耦合,可以减少代码的复杂度和维护成本,使代码设计更人性化。


链接: https://fly63.com/nav/3961

more>>
相关栏目
layer
layer是一款口碑极佳的web弹层组件
点击进入GitHub
iScroll.js
IScroll是移动页面上被使用的一款仿系统滚动插件。
官网GitHub
wangEditor
基于javascript和css开发的 Web富文本编辑器
官网GitHub
ueditor
由百度web前端研发部开发所见即所得富文本web编辑器
官网GitHub
highlight
Highlight.js 是一个用 JavaScript 写的代码高亮插件,在客户端和服务端都能工作。
官网GitHub
UglifyJS
一个js 解释器、最小化器、压缩器、美化器工具集
官网GitHub
lozad.js
高性能,轻量级,可配置的懒加载图片工具
官网GitHub
Sortable.js
简单灵活的 JavaScript 拖放排序插件
官网GitHub
validate.js
表单提供了强大的验证功能,让客户端表单验证变得更简单
官网GitHub
Draggin.js
一款兼容移动手机的js拖拽插件
官网GitHub
lazysizes.js
响应式图像延迟加载JS插件【懒加载】
官网GitHub
cropper.js
通过canvas实现图片裁剪
官网GitHub
clipboard.js
浏览器中复制文本到剪贴板的插件,不需要Flash,仅仅2kb
官网GitHub
siema
轻量级简单的纯 Js轮播插件
官网GitHub
Mermrender
用于生成序列和UML图的RESTful渲染管道
官网GitHub
Editor.js
JSON格式输出数据的富文本和媒体编辑器
官网GitHub

手机预览