在React里面使用mobx状态管理详细步骤

本文主要是介绍在React里面使用mobx状态管理详细步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、安装MobX和MobX React:

在你的项目目录下运行以下命令安装MobX和MobX React:

npm install mobx mobx-react

2、创建MobX Store:

创建一个用于管理状态的MobX Store。这个Store应该包含你希望全局管理的状态和相关的操作。以下是一个简单的示例:

// store.js
import { makeAutoObservable } from 'mobx';class AppStore {counter = 0;constructor() {makeAutoObservable(this);}increment() {this.counter += 1;}decrement() {this.counter -= 1;}
}const appStore = new AppStore();
export default appStore;export const useStore = () => appStore;

3、使用MobX Provider:

在你的应用中,使用MobxProvider包裹整个应用,同时将创建的MobX Store传递给Provider:

import React from 'react';
import { Provider } from 'mobx-react';
import App from './App';
import store from './mobxStore/store';
import { createRoot } from 'react-dom/client';// 使用 ReactDOM.createRoot 创建 React 根节点
const root = createRoot(document.getElementById('root'));// 在根节点上渲染应用
root.render(<React.StrictMode>{/* 使用 MobxProvider 包裹整个应用,并传递 MobX Store */}<Provider store={store}><App /></Provider></React.StrictMode>
);

4、获取 MobX Store

在你的React组件中使用MobX状态和操作。你可以使用MobX提供的useStore hook或者@inject注解。

// App.js
import React from 'react';
import { useObserver } from 'mobx-react';
import { useStore } from './mobxStore';const App = () => {const store = useStore();return useObserver(() => (<div><h1>Counter: {store.counter}</h1><button onClick={() => store.increment()}>Increment</button><button onClick={() => store.decrement()}>Decrement</button></div>));
};export default App;
// mobxStore.js
import { createContext, useContext } from 'react';class AppStore {// ... (同上)
}const appStore = new AppStore();const MobxStoreContext = createContext();export const MobxProvider = ({ children }) => (<MobxStoreContext.Provider value={appStore}>{children}</MobxStoreContext.Provider>
);export const useStore = () => {const store = useContext(MobxStoreContext);if (!store) {throw new Error('useStore must be used within a MobxProvider');}return store;
};export default appStore;

5、@inject注解。是什么

在MobX中,@inject是一个装饰器(Decorator),它用于将数据注入到React组件中。该装饰器的作用是将指定的mobx store(或者stores)中的数据注入到组件的props中,以便在组件中直接访问mobx的状态和操作。

在使用@inject装饰器之前,你需要确保你的项目支持装饰器语法。如果你使用的是Create React App等工具,它们可能需要额外的配置。在许多现代React应用中,支持装饰器语法已经默认启用。

以下是一个简单的例子,演示了如何使用@inject

// mobxStore.js
import { observable, action } from 'mobx';class CounterStore {@observable count = 0;@action increment() {this.count += 1;}@action decrement() {this.count -= 1;}
}const counterStore = new CounterStore();
export default counterStore;
// App.js
import React from 'react';
import { observer, inject } from 'mobx-react';// 使用 @inject 注入 counterStore
@inject('counterStore')
@observer
class App extends React.Component {render() {const { counterStore } = this.props;return (<div><h1>Counter: {counterStore.count}</h1><button onClick={() => counterStore.increment()}>Increment</button><button onClick={() => counterStore.decrement()}>Decrement</button></div>);}
}export default App;

在这个例子中,@inject('counterStore')注入了一个名为counterStore的mobx store到App组件的props中。然后,@observer装饰器使得组件能够观察mobx状态的变化,实时更新UI。

请注意,@inject的参数是要注入的mobx stores的名称。在上述例子中,counterStore是一个实例,但你可以有多个不同的stores,然后在@inject中指定需要的stores名称。

在使用装饰器语法的同时,确保你的项目配置支持装饰器。在Create React App中,你可能需要使用react-app-rewired等工具来进行额外的配置。

这篇关于在React里面使用mobx状态管理详细步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587793

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa