Rumah >hujung hadapan web >tutorial js >Belajar Zustand Sekarang dengan Cara Paling Mudah!
Menguruskan keadaan dalam React tidak pernah semudah dan ringan ini! Temui Zustand, perpustakaan pengurusan negeri yang kecil tetapi berkuasa yang akan menjadikan hidup anda lebih mudah sebagai pembangun. Sama ada anda bosan dengan boilerplate Redux atau had API Konteks, Zustand bersedia untuk menyelamatkan hari ini.
Dalam siaran ini, saya akan memperkenalkan Zustand dan berkongsi projek permulaan yang telah saya bina, tersedia di GitHub. Ikuti bersama untuk bermula dengan Zustand dalam projek Next.js dalam beberapa langkah sahaja! ?
Zustand (Bahasa Jerman untuk "negeri") ialah perpustakaan pengurusan negeri minimalis untuk React. Ia menawarkan:
Sekarang, mari kita mendalami penyediaannya dalam projek Next.js anda!
Ikuti langkah mudah ini untuk menyepadukan Zustand ke dalam apl Next.js anda.
Jalankan arahan berikut untuk memasang Zustand:
npm i zustand
Di dalam folder src anda, buat folder baharu bernama stor. Ini akan menyimpan semua fail keadaan Zustand anda.
src/ store/ index.ts userStore.ts
Kedai ini akan mengendalikan data berkaitan pengguna.
import { create } from "zustand"; interface User { id: string; name: string; email: string; } interface UserStore { user: User | null; setUser: (user: User | null) => void; } export const useUserStore = create<UserStore>((set) => ({ user: null, setUser: (user: User | null) => set({ user }), }));
Kedai ini akan mengendalikan keadaan balas dan mengekalkannya dalam localStorage.
"use client"; import { create } from "zustand"; import { persist, createJSONStorage } from "zustand/middleware"; interface ICounterStore { counter: number; increment : ()=> void; decrement : ()=> void; reset : ()=> void; getLatestCountDivided2: ()=> number; } export const useCounterStore = create<ICounterStore>()( persist( (set, get) => ({ counter: 0, increment: () => set(state => ({ counter: state.counter + 1 })), decrement: () => set(state => ({ counter: state.counter - 1 })), reset: () => set({ counter: 0 }), getLatestCountDivided2: ()=> get().counter / 2, }), { name: "counter-store", storage: createJSONStorage(()=> localStorage), } ) );
Fail ini akan mengeksport semua kedai untuk import yang lebih mudah.
import { useUserStore } from "./userStore"; import { useCounterStore } from "./counterStore"; export { useUserStore, useCounterStore };
Berikut ialah contoh cara menggunakan stor Zustand dalam komponen Next.js anda.
"use client"; import { useCounterStore, useUserStore } from "@/store"; import Link from "next/link"; export default function Home() { // Access Zustand stores const userStore = useUserStore(); const counterStore = useCounterStore(); const handleAddUser = () => { userStore.setUser({ id: "1", name: "Joodi", email: "mail@example.com" }); }; return ( <div className=""> <div className="flex gap-2 p-2"> <Link className="p-2 border" href="/">Home</Link> <Link className="p-2 border" href="/about">About</Link> <Link className="p-2 border" href="/contact">Contact</Link> </div> <h1>Hello</h1> <h1>User: {userStore.user?.email}</h1> <button className="bg-blue-500 rounded-md p-2 text-white" onClick={handleAddUser} > Add User </button> <br /> <h1>Counter: {counterStore.counter}</h1> <button className="bg-blue-500 rounded-md text-white p-2" onClick={counterStore.increment}> Increment </button> <button className="bg-blue-500 rounded-md text-white p-2" onClick={counterStore.decrement}> Decrement </button> <button className="bg-blue-500 rounded-md text-white p-2" onClick={counterStore.reset}> Reset </button> </div> ); }
Kod penuh untuk projek permulaan ini tersedia di GitHub. Ia mesra pemula dan termasuk semua yang anda perlukan untuk mula menggunakan Zustand dengan Next.js.
Klon repositori dan mulakan:
git clone https://github.com/MiladJoodi/Zustand_Starter_Project.git cd Zustand_Starter_Project npm install npm run dev
Mula mengurus negeri anda dengan mudah dengan Zustand. Beritahu saya pendapat anda atau kongsi kes penggunaan anda sendiri! ?
Atas ialah kandungan terperinci Belajar Zustand Sekarang dengan Cara Paling Mudah!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!