zustand管理工具--React

npm i zustand

1.函数参数必须返回一个对象 对象内部编写状态数据和方法

2.set是用来修改数据的专门方法必须调用它来修改数据

import { useEffect } from "react";
import { create } from "zustand";

// 1. 创建store
const goodsStore = create((set) => ({
  count: 1,
  inc: () => set((state) => ({ count: state.count + 1 })),
  channelList: [],
  // 异步方法
  fetchChannelList: async () => {
    const res = await fetch(URL);
    const jsonData = await res.json();

    set({ channelList: jsonData.data.channels });
  },
}));

// 2. 绑定store到组件
function Counter() {
  const { count, inc, channelList, fetchChannelList } = goodsStore();

  useEffect(() => {
    fetchChannelList()
  }, [fetchChannelList])

  return (
    <div>
      <button onClick={inc}>{count}</button>
      <ul>
        {channelList.map((item) => {
          return <li key={item.id}>{item.name}</li>;
        })}
      </ul>
    </div>
  );
}

export default Counter;

3.切片模式--模块化

import { useEffect } from "react";
import { create } from "zustand";

// 1. 创建store
const goodsStore = (set) => ({
  count: 1,
  inc: () => set((state) => ({ count: state.count + 1 })),
});

const channelListStore = (set) => ({
  channelList: [],
  // 异步方法
  fetchChannelList: async () => {
    const res = await fetch(URL);
    const jsonData = await res.json();

    set({ channelList: jsonData.data.channels });
  },
});

const useStore = create((...a) => ({
    ...goodsStore(...a),
    ...channelListStore(...a),
  }));

// 2. 绑定store到组件
function Counter() {
  const { count, inc, channelList, fetchChannelList } = useStore();

  useEffect(() => {
    fetchChannelList();
  }, [fetchChannelList]);

  return (
    <div>
      <button onClick={inc}>{count}</button>
      <ul>
        {channelList.map((item) => {
          return <li>{item}</li>;
        })}
      </ul>
    </div>
  );
}

export default Counter;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值