如何使用react创建单例组件

这次给大家带来如何使用react创建单例组件,使用react创建单例组件的注意事项有哪些,下面就是实战案例,一起来看一下。

需求背景

最近有个需求,需要在项目中添加一个消息通知弹窗,告知用户一些信息。

用户看过消息后,就不再弹窗了。

问题

很明显,这个需要后端的介入,提供相应的接口(这样可扩展性更好)。

在开发过程中,遇到个问题:由于我们的系统是多页面的,所以每次切换页面,都会去请求后端的消息接口。。有一定的性能损耗。

因为是多页面系统,使用单例组件貌似也没啥意义(不过是个机会学习学习单例组件是怎么写的)。
于是,想到使用浏览器缓存来记录是否弹过窗了(当然,得设定过期时间)。

如何写单例组件

1、工具函数:

import ReactDOM from 'react-dom';/** * ReactDOM 不推荐直接向 document.body mount 元素 * 当 node 不存在时,创建一个 p */function domRender(reactElem, node) { let p; if (node) {  p = typeof node === 'string'   ? window.document.getElementById(node)   : node; } else {  p = window.document.createElement('p');  window.document.body.appendChild(p); } return ReactDOM.render(reactElem, p);}

登录后复制

2、组件:

export class SingletonLoading extends Component { globalLoadingCount = 0; pageLoadingCount = 0; state = {  show: false,  className: '',  isGlobal: undefined } delayTimer = null; start = (options = {}) => {  // ... } stop = (options = {}) => {  // ... } stopAll() {  if (!this.state.show) return;  this.globalLoadingCount = 0;  this.pageLoadingCount = 0;  this.setState({show: false}); } get isGlobalLoading() {  return this.state.isGlobal && this.state.show; } get noWaiting() {  return this.noGlobalWaiting && this.pageLoadingCount < 1; } get toPageLoading() {  return this.noGlobalWaiting && this.isGlobalLoading; } get noGlobalWaiting() {  return this.globalLoadingCount < 1; } render() {  return ; }}// 使用上面的工具函数export const loading = domRender();

登录后复制

3、使用组件:

import loading from 'xxx';// ...loading.start();loading.stop();

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

如何使用vue中filter

怎样使用vue判断dom的class

以上就是如何使用react创建单例组件的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2751239.html

(0)
上一篇 2025年3月8日 05:48:40
下一篇 2025年2月23日 22:03:35

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论