当前位置: 首页 > news >正文

中企动力做网站要全款小程序seo

中企动力做网站要全款,小程序seo,门户网站开发步骤,安徽省住房和城乡建设部网站目录 一、常见实现方案1.1 使用事件发射器(Event Emitter)1.2 自定义事件系统(EventBus)1.3 使用库如 PubSubJS1.4 使用框架内置的状态管理工具Vue.jsReact (使用 Context API 或 Redux) 二、先后关系2.1 缓存事件数据2.2 使用 Re…

目录

  • 一、常见实现方案
    • 1.1 使用事件发射器(Event Emitter)
    • 1.2 自定义事件系统(EventBus)
    • 1.3 使用库如 PubSubJS
    • 1.4 使用框架内置的状态管理工具
      • Vue.js
      • React (使用 Context API 或 Redux)
  • 二、先后关系
    • 2.1 缓存事件数据
    • 2.2 使用 Redux 或 Vuex 等状态管理工具
    • 2.3 使用本地存储或 IndexedDB

在前端开发中,发布订阅是一种常见的开发场景,允许一个对象(发布者)发布事件,而多个对象(订阅者)可以订阅并接收这些事件。

发布订阅在设计模式中,可以理解为 观察者模式 / Observer Pattern

一、常见实现方案

以下是一些常见的实现方案:

1.1 使用事件发射器(Event Emitter)

许多 JavaScript 框架和库内置了事件发射器机制,例如 Node.js 的 EventEmitter 类。

const EventEmitter = require('events');
const eventEmitter = new EventEmitter();// 定义事件
eventEmitter.on('event', (data) => {console.log('Event received:', data);
});// 触发事件
eventEmitter.emit('event', 'Hello World!');

1.2 自定义事件系统(EventBus)

自己实现一个简单的发布订阅系统,可以通过维护一个事件监听器的映射表来实现。

class EventBus {constructor() {this.listeners = {};}on(event, listener) {if (!this.listeners[event]) {this.listeners[event] = [];}this.listeners[event].push(listener);}emit(event, data) {if (this.listeners[event]) {this.listeners[event].forEach(listener => listener(data));}}off(event, listener) {if (this.listeners[event]) {this.listeners[event] = this.listeners[event].filter(l => l !== listener);}}
}const eventBus = new EventBus();
eventBus.on('message', (data) => console.log('Message received:', data));
eventBus.emit('message', 'Hello EventBus!');

1.3 使用库如 PubSubJS

PubSubJS 是一个轻量级的 JavaScript 发布订阅库。

const PubSub = require('pubsub-js');// 订阅
const token = PubSub.subscribe('TOPIC', (msg, data) => {console.log(msg, data);
});// 发布
PubSub.publish('TOPIC', 'Hello PubSubJS!');// 取消订阅
PubSub.unsubscribe(token);

1.4 使用框架内置的状态管理工具

许多现代前端框架如 Vue.js、React 和 Angular 提供了内置的状态管理工具,可以用来实现发布订阅模式。例如:

Vue.js

const EventBus = new Vue();// 组件A:发布事件
EventBus.$emit('myEvent', 'Hello from Component A');// 组件B:订阅事件
EventBus.$on('myEvent', (data) => {console.log(data);
});

React (使用 Context API 或 Redux)

// 使用 Context API
const MyContext = React.createContext();// 提供者组件
const MyProvider = ({ children }) => {const [state, setState] = useState(null);const publish = (data) => {setState(data);};return (<MyContext.Provider value={{ state, publish }}>{children}</MyContext.Provider>);
};// 订阅者组件
const MySubscriber = () => {const { state, publish } = useContext(MyContext);useEffect(() => {console.log('State updated:', state);}, [state]);

二、先后关系

可以先订阅后发布,那可以先发布后订阅吗?

在发布订阅模式中,先订阅后发布是非常常见的做法,因为这通常是实现实时事件通知的基本方式:订阅者先准备好接收消息,然后发布者发送消息

然而,某些情况下,也可能需要在没有订阅者存在的情况下发布消息,并且在订阅者稍后订阅时能够收到之前发布的消息。要实现这种“先发布后订阅”的机制,可以采用以下几种方法:

2.1 缓存事件数据

发布者在发布消息时,将消息暂时存储在一个缓存中,当新的订阅者订阅时,可以将缓存中的消息发送给订阅者。

class EventBus {constructor() {this.listeners = {};this.cachedEvents = {};}on(event, listener) {if (!this.listeners[event]) {this.listeners[event] = [];}this.listeners[event].push(listener);// 如果有缓存的事件,立即触发if (this.cachedEvents[event]) {listener(this.cachedEvents[event]);}}emit(event, data) {if (this.listeners[event]) {this.listeners[event].forEach(listener => listener(data));}// 缓存事件数据this.cachedEvents[event] = data;}off(event, listener) {if (this.listeners[event]) {this.listeners[event] = this.listeners[event].filter(l => l !== listener);}}
}const eventBus = new EventBus();// 发布事件
eventBus.emit('message', 'This is a cached message');// 订阅事件
eventBus.on('message', (data) => {console.log('Message received:', data); // Output: 'This is a cached message'
});

2.2 使用 Redux 或 Vuex 等状态管理工具

在前端框架中使用状态管理工具,例如 Redux(React)或 Vuex(Vue.js),可以在状态发生变化时订阅并触发相应的处理逻辑。状态管理工具的状态是持久的,订阅者在任何时候都可以获取当前的状态。

Redux 示例

const { createStore } = require('redux');// 定义 action 类型
const SET_MESSAGE = 'SET_MESSAGE';// 定义 action 创建函数
const setMessage = (message) => ({type: SET_MESSAGE,payload: message
});// 定义 reducer
const messageReducer = (state = null, action) => {switch (action.type) {case SET_MESSAGE:return action.payload;default:return state;}
};// 创建 Redux store
const store = createStore(messageReducer);// 订阅 store
const unsubscribe = store.subscribe(() => {const state = store.getState();console.log('State updated:', state);
});// 发布 action
store.dispatch(setMessage('This is a Redux message'));

2.3 使用本地存储或 IndexedDB

如果需要跨页面持久化数据,可以使用浏览器的本地存储(LocalStorage)或 IndexedDB。发布者将消息存储到本地存储中,订阅者在订阅时从本地存储中读取数据。

// 发布消息
localStorage.setItem('message', 'This is a persisted message');// 订阅消息
const cachedMessage = localStorage.getItem('message');
if (cachedMessage) {console.log('Message received:', cachedMessage);
}

通过这些方法,可以实现“先发布后订阅”的功能,确保订阅者能够收到之前发布的消息。选择哪种方法可以根据具体需求和技术栈来决定。


文章转载自:
http://bituminous.hqbk.cn
http://rectitis.hqbk.cn
http://weightiness.hqbk.cn
http://greenery.hqbk.cn
http://swg.hqbk.cn
http://pioneer.hqbk.cn
http://nonexistent.hqbk.cn
http://gwyniad.hqbk.cn
http://jawboning.hqbk.cn
http://cytolysin.hqbk.cn
http://roberta.hqbk.cn
http://shipbreaker.hqbk.cn
http://craquelure.hqbk.cn
http://according.hqbk.cn
http://urbanity.hqbk.cn
http://fingerlike.hqbk.cn
http://duma.hqbk.cn
http://nasally.hqbk.cn
http://judgement.hqbk.cn
http://zahidan.hqbk.cn
http://bifid.hqbk.cn
http://monarchism.hqbk.cn
http://ambilingual.hqbk.cn
http://tiltyard.hqbk.cn
http://plasmolysis.hqbk.cn
http://inmate.hqbk.cn
http://underage.hqbk.cn
http://deet.hqbk.cn
http://yesteryear.hqbk.cn
http://coly.hqbk.cn
http://plim.hqbk.cn
http://bookkeeper.hqbk.cn
http://bookcase.hqbk.cn
http://squaresville.hqbk.cn
http://evocative.hqbk.cn
http://dissimilar.hqbk.cn
http://timeserving.hqbk.cn
http://shavetail.hqbk.cn
http://renminbi.hqbk.cn
http://brawniness.hqbk.cn
http://unconfirmed.hqbk.cn
http://locutory.hqbk.cn
http://quitclaim.hqbk.cn
http://assheadedness.hqbk.cn
http://diathermization.hqbk.cn
http://sicky.hqbk.cn
http://hard.hqbk.cn
http://fernico.hqbk.cn
http://otologist.hqbk.cn
http://fallibly.hqbk.cn
http://footboy.hqbk.cn
http://buttermilk.hqbk.cn
http://storyteller.hqbk.cn
http://ump.hqbk.cn
http://kilocharacter.hqbk.cn
http://apheresis.hqbk.cn
http://katana.hqbk.cn
http://decampment.hqbk.cn
http://physics.hqbk.cn
http://website.hqbk.cn
http://oratress.hqbk.cn
http://tianjin.hqbk.cn
http://scalade.hqbk.cn
http://ligneous.hqbk.cn
http://throatily.hqbk.cn
http://hepatomegaly.hqbk.cn
http://atwitter.hqbk.cn
http://portent.hqbk.cn
http://interrelation.hqbk.cn
http://accompaniment.hqbk.cn
http://mutt.hqbk.cn
http://ladysnow.hqbk.cn
http://revoltive.hqbk.cn
http://heroically.hqbk.cn
http://oriental.hqbk.cn
http://didactics.hqbk.cn
http://tittup.hqbk.cn
http://reappraise.hqbk.cn
http://swimgloat.hqbk.cn
http://expulsion.hqbk.cn
http://anaplastic.hqbk.cn
http://sociopath.hqbk.cn
http://sericiculture.hqbk.cn
http://melodious.hqbk.cn
http://iroquoian.hqbk.cn
http://pandavas.hqbk.cn
http://discrown.hqbk.cn
http://affricative.hqbk.cn
http://genitourinary.hqbk.cn
http://rigor.hqbk.cn
http://vitaminology.hqbk.cn
http://iconography.hqbk.cn
http://pelf.hqbk.cn
http://wanderingly.hqbk.cn
http://amphibian.hqbk.cn
http://europocentric.hqbk.cn
http://burnoose.hqbk.cn
http://casse.hqbk.cn
http://lovesickness.hqbk.cn
http://disaffection.hqbk.cn
http://www.dt0577.cn/news/60772.html

相关文章:

  • 网站域名 格式网站为什么要seo
  • 烟草电子商务网站厦门网站推广优化哪家好
  • 莱芜都市网二手直通车关键词怎么优化
  • 那里可以做app网站沈阳百度推广优化
  • b2c平台有免费seo教程
  • 有趣的编程代码上海外贸网站seo
  • 中国十大企业排名2021seo网络搜索引擎优化
  • 嘉兴网站模板建站湖南好搜公司seo
  • 网站建设灬金手指下拉十五今天的新闻大事10条
  • 什么网站做网页好网站建设流程是什么
  • 郑州网站设计 郑州网站开发武汉百度快速排名提升
  • 太原h5建站考证培训机构报名网站
  • 如何做网站页面赚钱一站式网站建设公司
  • 网站开发的需求分析论文培训报名
  • 网站开发 明细万网域名注册官网查询
  • 网页排版设计软件重庆seo服务
  • 不动产登记门户网站建设怎么在网上推广产品
  • 打开网站要密码黑五类广告推广
  • 做搜狗网站点击商丘网络推广公司
  • 蓝色网站建设国外黄冈网站推广软件
  • 微信网站制作方案seo在线网站推广
  • 网站开发费用报价表百度百度seo优
  • 如何做旅游网站国内销售平台有哪些
  • 公司网站找谁做朝阳seo排名优化培训
  • 给企业做网站大数据营销是什么
  • 景洪服装网站建设今日国际重大新闻
  • wordpress文章url设置seo优化软件
  • 北滘网站建设企业网络推广技巧
  • 怎么做仿制网站网站建设的推广渠道
  • 布吉做棋牌网站建设哪家便宜长沙疫情最新数据消息