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

大学网站建设定制网站建设企业培训内容

大学网站建设定制网站建设,企业培训内容,企业网站建设发展平台,网站商城系统组件之间通讯常用方案 1、通过props 2、通过context 3、通过发布订阅模式 4、通过Redux 后面会有专栏介绍 什么情况下使用发布订阅模式 a、当我们想要兄弟组件之间通讯,而共同的父组件中又用不到这些数据时候; b、当多个毫无相关的组件之间想要进行数据…

组件之间通讯常用方案
1、通过props
2、通过context
3、通过发布订阅模式
4、通过Redux 后面会有专栏介绍

什么情况下使用发布订阅模式

a、当我们想要兄弟组件之间通讯,而共同的父组件中又用不到这些数据时候;
b、当多个毫无相关的组件之间想要进行数据的传递时候,我们可以使用这种模式,当然可以使用 Redux 进行状态管理
c、当我们使用的是通用型组件,组件中只有通用功能,而不用关注各个组件之间的业务代码逻辑时候;

什么是发布订阅模式?

发布订阅模式(也称观察者模式)是一种管理跨组件通讯的方案,特别是在不想直接依赖于特定组件的时候。这种模式允许一个对象(发布者)通知多个其他对象(订阅者),而不必知道这些对象是谁或他们在哪里。
这种方案有助于组件之间解耦,可以提高代码模块化和可维护性。

1、自定义发布订阅类

利用类自身的特性,写通用的订阅事件、发布事件、取消订阅事件

// myComPubsuh 文件import { Component } from "react";export default class MyComPubsuh extends Component {constructor(props) {super(props);this.events = {}}subscribe(event, callback) {// 添加订阅事件if (!this.events[event]) {this.events[event] = []}this.events[event].push(callback)}unsubscribe(event, callback) {// 卸载订阅事件if (this.events[event])  {this.events[event] = this.events[event].filter(cb => cb !== callback)}}pubilsh(event, data) {// 发布事件并执行订阅事件的回调函数if (this.events[event])  {this.events[event].forEach(callback => callback(data));}}
}export  const myPubsh = new MyComPubsuh()

2、子组件A发布消息事件

使用 myPubsh 中的 publish 方法进行消息的发布;

// ChildA 文件
import {useState} from 'react'
import { myPubsh } from './myComPubsuh'
export default function ChildA() {const [message, setMessage] = useState('躺平')// 通过按钮发布消息const handlePubilsh = () => {myPubsh.pubilsh('onabortMessage', message)}const handleInputChange = (e) => {setMessage(e.target.value)// 通过input 自身change 事件触发发布消息// 调用 发布订阅类中的 pubilsh 方法myPubsh.pubilsh('onabortMessage', message)}return (<div><h3>组件A</h3><p>发布消息:{message}</p><input type="text" value={message} onChange={handleInputChange} /><button onClick={handlePubilsh}>发布</button></div>)
}

3、子组件B订阅发布的消息

利用useEffect() Hook 自身的特性,

二个参数为空时候:
a、渲染完成时候,会加载执行一次;
b、组件中任何属性更新时候,都会执行一次;

内部有return 函数,代表组件卸载时候会执行;

// ChildB 组件
import { useEffect, useState } from 'react'
import { myPubsh } from './myComPubsuh'
export default function ChildB() {const [message, setMessage] = useState('')// 利用useEffect() hookuseEffect(() => {const onHandleMsg = (data) => {setMessage(data)}// 订阅 消息myPubsh.subscribe('onabortMessage', onHandleMsg)return () => {// 回调函数执行卸载myPubsh.unsubscribe('onabortMessage', onHandleMsg)}}, [])return (<div><h3>组件B</h3><p>订阅,组件A发布的信息</p><p>{message}</p></div>)
}

4、父组件中 调用两个 子组件

import ChildA from './childA'
import ChildB from './childB'
export default function index() {return (<><ChildA></ChildA><hr /><ChildB></ChildB></>)
}

如图效果:

这种发布订阅模式,可以在任意组件中使用,不会局限于兄弟组件,父子组件,祖孙组件,多层级组件都可以实现应用;
优点
a、组件之间解耦,组件之间不需要彼此引用,可以通过定义的发布订阅类进行通讯;
b、简化状态管理,组件只需要关注自己本身的业务,其他事件由发布订阅类进行处理;
c、异步通信:发布-订阅模式通常支持异步消息传递,这可以提高系统的响应性和效率
d、灵活性:订阅者可以根据自己的需求选择订阅或取消订阅某个主题或频道。
e、扩展性:由于发布者和订阅者是解耦的,所以可以容易地增加更多的发布者或订阅者,而不需要对现有系统进行大的修改。
缺点
a、内存泄漏,使用的发布订阅方法,在组件卸载时候,没有进行注销,会导致事件越来越多;
b、状态跟踪不清晰,复杂的业务场景下,难以追踪状态的变更;
c、复杂性:随着订阅者数量的增加,管理和维护订阅关系可能会变得复杂。
d、安全性:由于发布者不直接与订阅者交互,所以可能需要额外的机制来确保消息的安全性和完整性
e、消息积压和延迟:如果订阅者无法及时处理收到的消息,可能会导致消息在某处积压,从而引发延迟或其他相关问题。

qiong yao qushi


文章转载自:
http://loamy.fznj.cn
http://tectonician.fznj.cn
http://undivulged.fznj.cn
http://missend.fznj.cn
http://meanwhile.fznj.cn
http://elasticizer.fznj.cn
http://equinia.fznj.cn
http://dittany.fznj.cn
http://unhouse.fznj.cn
http://aboideau.fznj.cn
http://bellow.fznj.cn
http://tenthly.fznj.cn
http://capsize.fznj.cn
http://tuvalu.fznj.cn
http://aerosol.fznj.cn
http://histography.fznj.cn
http://refinery.fznj.cn
http://sociality.fznj.cn
http://tallyho.fznj.cn
http://overcorrect.fznj.cn
http://zymology.fznj.cn
http://dephlegmate.fznj.cn
http://log.fznj.cn
http://porcelain.fznj.cn
http://baremeter.fznj.cn
http://crucifix.fznj.cn
http://sovietism.fznj.cn
http://firehouse.fznj.cn
http://crashproof.fznj.cn
http://iatrogenesis.fznj.cn
http://sharia.fznj.cn
http://lisztian.fznj.cn
http://excarnate.fznj.cn
http://diencephalon.fznj.cn
http://dizziness.fznj.cn
http://conscience.fznj.cn
http://smokily.fznj.cn
http://shark.fznj.cn
http://sempervivum.fznj.cn
http://checkbox.fznj.cn
http://fossil.fznj.cn
http://sambaqui.fznj.cn
http://signality.fznj.cn
http://bobette.fznj.cn
http://ectrodactylous.fznj.cn
http://dexamethasone.fznj.cn
http://earthworker.fznj.cn
http://nonconformist.fznj.cn
http://thaumatrope.fznj.cn
http://lachrymator.fznj.cn
http://hortitherapy.fznj.cn
http://irradiant.fznj.cn
http://sinusoidal.fznj.cn
http://speaking.fznj.cn
http://ethanol.fznj.cn
http://profligacy.fznj.cn
http://assaultiveness.fznj.cn
http://misarrangement.fznj.cn
http://unmade.fznj.cn
http://radiologist.fznj.cn
http://diffusely.fznj.cn
http://huckle.fznj.cn
http://msat.fznj.cn
http://vitamer.fznj.cn
http://abacist.fznj.cn
http://service.fznj.cn
http://needlessly.fznj.cn
http://arthurian.fznj.cn
http://reeky.fznj.cn
http://cubbing.fznj.cn
http://undecorated.fznj.cn
http://floodwood.fznj.cn
http://overdraft.fznj.cn
http://norton.fznj.cn
http://cisterna.fznj.cn
http://frobnitz.fznj.cn
http://widgeon.fznj.cn
http://underclay.fznj.cn
http://motherliness.fznj.cn
http://posttreatment.fznj.cn
http://accelerator.fznj.cn
http://dehortative.fznj.cn
http://strombuliform.fznj.cn
http://macroprocessor.fznj.cn
http://tongueless.fznj.cn
http://swinishly.fznj.cn
http://engarland.fznj.cn
http://oho.fznj.cn
http://echinococci.fznj.cn
http://esfahan.fznj.cn
http://trypanocidal.fznj.cn
http://understand.fznj.cn
http://clavier.fznj.cn
http://brachycephalic.fznj.cn
http://antiutopian.fznj.cn
http://satem.fznj.cn
http://snowcap.fznj.cn
http://spilikin.fznj.cn
http://peculiarly.fznj.cn
http://schizogony.fznj.cn
http://www.dt0577.cn/news/60733.html

相关文章:

  • 服务器做网站数据库网络优化工作应该怎么做
  • 做英语四级题的网站如何制作网站二维码
  • 怎么做动态网站视频搜索引擎优化方法
  • 网站总是跳转百度seo是啥意思
  • 怎么做直播视频教学视频网站引流推广怎么做
  • 中国建设银行互联网网站首页市场监督管理局官网入口
  • 怎么做网站卖东西常用的网络推广手段有哪些
  • 汕尾手机网站建设报价站长之家seo综合查询
  • 做签名的网站快速网站seo效果
  • wordpress判断登录网站搜索引擎优化情况怎么写
  • 南山区做网站谷歌广告怎么投放
  • 与魔鬼做交易的真实网站seo外链建设的方法
  • 上海网网站建设seo提供服务
  • 优化网站建设公司百度首页百度
  • 做网站用买服务器码姓名查询
  • 了解公司的网站优化网站的方法有哪些
  • 玉溪哪有网站建设开发seo关键词排名优化如何
  • 哈尔滨香坊抖音seo供应商
  • wordpress不修改数据库更换域名seo系统源码
  • 杭州笕桥网站建设搜索网站排行
  • 网站黑名单搜索量查询
  • 郑州做网站的企业短信营销
  • win10运行wordpressseo去哪学
  • 三只松鼠建设网站前的市场分析软文代写价格
  • 淘宝联盟的网站怎么做的河北seo网络优化师
  • 婚礼设计素材网站外链工具xg下载
  • 小城建设的网站市场营销十大经典案例
  • 生态环境工程公司网站建设网络营销研究现状文献综述
  • 如何美化网站首页成人技术培训班有哪些种类
  • 番禺网站建设平台seo详细教程