在 React 函数式组件中使用 MobX

🌟 MobX 是一个简洁的状态管理库📚,它通过透明的函数响应式编程(TFRP)🔮 使得状态管理变得简单和可扩展。在 React 函数式组件中使用 MobX 可以让我们更轻松地管理组件状态✨。这篇文章将介绍如何在 React 函数式组件中结合使用 MobX 和 mobx-react 包提供的 observer 函数👀 以及 Provider🏭 和 useContext🔗。

安装🛠️

首先,需要确保 mobxmobx-react 已经添加到项目依赖中。

shell 复制代码
npm install mobx mobx-react 📦

定义你的 Store 🗃️

创建一个 store 来存储应用状态📈。

javascript 复制代码
import { makeAutoObservable } from 'mobx';

class TodoStore {
  todos = [];

  constructor() {
    makeAutoObservable(this);
  }

  addTodo(todo) {
    this.todos.push(todo);
  }

  get todoCount() {
    return this.todos.length;
  }
}

export const todoStore = new TodoStore();

使用 ProvideruseContext 提供和使用 Store🔄

通过 Provider 可以将 store 传递到 React 组件树中🌲。然后,使用 React 的 useContext 钩子函数将 store 注入到函数式组件中。

创建一个 context:

javascript 复制代码
import { createContext } from 'react';
import { todoStore } from './TodoStore';

export const StoreContext = createContext(todoStore);

使用 Provider 将 store 提供给组件:

javascript 复制代码
import React from 'react';
import ReactDOM from 'react-dom';
import { StoreContext } from './store';
import App from './App';
import { todoStore } from './TodoStore';

ReactDOM.render(
  <StoreContext.Provider value={todoStore}>
    <App />
  </StoreContext.Provider>,
  document.getElementById('root')
);

在函数式组件中使用 Store🛠️

在函数式组件中,可以通过 useContext 钩子和 observer 函数来使用 store 和响应其变化🌀。

javascript 复制代码
import React, { useState, useContext } from 'react';
import { observer } from 'mobx-react';
import { StoreContext } from './store';

const TodoList = observer(() => {
  const store = useContext(StoreContext);
  const [newTodo, setNewTodo] = useState('');

  const handleInputChange = (e) => {
    setNewTodo(e.target.value);
  };

  const handleFormSubmit = (e) => {
    e.preventDefault();
    store.addTodo(newTodo);
    setNewTodo('');
  };

  return (
    <div>
      <form onSubmit={handleFormSubmit}>
        <input
          type="text"
          value={newTodo}
          onChange={handleInputChange}
        />
        <button type="submit">Add Todo</button>
      </form>
      <ul>
        {store.todos.map((todo, index) => (
          <li key={index}>{todo}</li>
        ))}
      </ul>
      <div>Total Todos: {store.todoCount}</div>
    </div>
  );
});

export default TodoList;

在上述代码中,TodoList 组件通过 useContext 获取到 todoStore🛍️,通过 observer 函数包裹组件以确保组件能响应状态变化🔄。每当状态更新时(如添加了一个 todo)✏️,TodoList 组件会重新渲染以反映最新的状态🔄。

通过使用 MobX、Provider🏭 和 React 的 Context API🔗,我们可以在函数式组件中便利地管理和使用状态✨。

相关推荐
ssshooter2 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
青青家的小灰灰11 小时前
迈向全栈新时代:SSR/SSG 原理、Next.js 架构与 React Server Components (RSC) 实战
前端·javascript·react.js
青青家的小灰灰11 小时前
透视 React 内核:Diff 算法、合成事件与并发特性的深度解析
前端·javascript·react.js
小霖家的混江龙13 小时前
从 0 到 1 实现一个 useState
前端·javascript·react.js
晓得迷路了13 小时前
栗子前端技术周刊第 118 期 - Oxfmt Beta、Angular GitHub stars、React 基金会...
前端·javascript·react.js
AAA阿giao1 天前
从零构建一个现代登录页:深入解析 Tailwind CSS + Vite + Lucide React 的完整技术栈
前端·css·react.js
昨晚我输给了一辆AE861 天前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码11 天前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码11 天前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
不会敲代码11 天前
从入门到进阶:手写React自定义Hooks,让你的组件更简洁
前端·react.js