在大型项目中组织 MobX 目录和使用 MobX 进行状态管理

在大型项目中,组织 MobX 目录和使用 MobX 进行状态管理非常重要。以下是一个推荐的目录结构和使用 MobX 的代码示例。

目录结构

src/
├── components/
│   ├── Cart.tsx
│   ├── Navbar.tsx
│   └── ProductList.tsx
├── pages/
│   ├── _app.tsx
│   ├── index.tsx
│   └── cart.tsx
├── stores/
│   ├── index.ts
│   ├── ProductStore.ts
│   ├── CartStore.ts
│   └── RootStore.ts
├── services/
│   └── api.ts
├── styles/
│   ├── globals.css
│   ├── Home.module.css
│   └── Cart.module.css
└── utils/
    └── helpers.ts

1. 创建 RootStore

RootStore 用于组织和管理所有子 store。

// stores/RootStore.ts
import ProductStore from './ProductStore';
import CartStore from './CartStore';

class RootStore {
   
  productStore: ProductStore;
  cartStore: CartStore;

  constructor() {
   
    this.productStore = new ProductStore(this);
    this.cartStore = new CartStore(this);
  }
}

export default RootStore;

2. 创建 ProductStore

ProductStore 用于管理商品相关的状态和操作。

// stores/ProductStore.ts
import {
    makeAutoObservable } from 'mobx';
import RootStore from './RootStore';

class ProductStore {
   
  rootStore: RootStore;
  products = [];

  constructor(rootStore: RootStore) {
   
    this.rootStore = rootStore;
    makeAutoObservable(this);
  }

  setProducts(products) {
   
    this.products = products;
  }

  async fetchProducts() {
   
    const response = await fetch('/api/products');
    const products = await response.json();
    this.setProducts(products);
  }
}

export default ProductStore;

3. 创建 CartStore

CartStore 用于管理购物车相关的状态和操作。

// stores/CartStore.ts
import {
    makeAutoObservable } from 'mobx';
import RootStore from './RootStore';

class CartStore {
   
  rootStore: RootStore;
  cart 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛飞之

感激不尽

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值