zustand使用

安装

npm install zustand

对于简单的状态

(一层)

定义

E:\next-blog\zustandtest\store\index.ts

import { create } from 'zustand'


interface State {
    count: number,
    todoList: string[]
    todoItem: string
    name: string
}

type Action = {
    increaseCount: () => void
    setTodoList: (item: string) => void
    setTodoItem: (item: string) => void
    updateName: (item: string) => void
}

export const useStore = create()(
    (set) => ({
        count: 0,
        todoList: [],
        todoItem: "",
        name: "",
        increaseCount: () => set((state) => ({ count: state.count + 1 })),
        setTodoList: (item) => set((state) => ({ todoList: [...state.todoList, item] })),
        setTodoItem: (item) => set(() => ({ todoItem: item })),
        updateName: (item) => set(() => ({ name: item }))
    }))
import { create } from 'zustand'

interface State {
    switchPage: string
}

type Action = {
    setswitchPage: (item: string) => void
}

export const useStore = create()(
    (set) => ({
        switchPage: "file",
        setswitchPage: (item) => set(() => ({ switchPage: item }))
    }))

调用

E:\next-blog\zustandtest\components\Todolists.tsx

"use client"
import { useStore } from '@/store'
import React from 'react'

const Todolists = () => {
    const todolist = useStore((state) => state.todoList)
    const todoItem = useStore((state) => state.todoItem)
    const setTodoItem = useStore((state) => state.setTodoItem)
    const setTodoList = useStore((state) => state.setTodoList)

对于复杂的状态

需要用到中间件

npm install immer

(多层)

import { create } from 'zustand'
import { immer } from 'zustand/middleware/immer'

interface ILog {
    where: string,
    who: string,
    done: string
}

interface State {
    log: ILog
}

type Action = {
    setLogName: (item: string) => void
    setLogWhere: (item: string) => void
    setLogDone: (item: string) => void
}

export const useStore = create()(
    immer((set) => ({
        log: {
            who: '',
            where: '',
            done: ''
        },
        setLogName: (item) =>
            set((state) => {
                state.log.who = item
            }),
            // 对象状态
        setLogWhere: (item) =>
            set((state) => {
                state.log.where = item
            }),
        setLogDone: (item) =>
            set((state) => {
                state.log.done = item
            }),
    })))
updateName: (item) => set(() => ({ name : item })),
updateName: (item) => set((state) => { state.name = item }),  //immer包裹

偶尔分享web开发知识
某破站
blog

你可能感兴趣的:(react,zustand)