Rumah >hujung hadapan web >tutorial js >Belajar Zustand Sekarang dengan Cara Paling Mudah!

Belajar Zustand Sekarang dengan Cara Paling Mudah!

Barbara Streisand
Barbara Streisandasal
2024-12-15 15:46:25694semak imbas

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! ?

Learn Zustand Right Now in the Simplest Way!

Apa itu Zustand? ?

Zustand (Bahasa Jerman untuk "negeri") ialah perpustakaan pengurusan negeri minimalis untuk React. Ia menawarkan:

  • API yang sangat ringkas.
  • Prestasi tinggi tanpa pemaparan semula yang tidak perlu.
  • Sintaks yang mudah difahami.
  • Sokongan perisian tengah terbina dalam (cth., untuk keadaan berterusan).

Sekarang, mari kita mendalami penyediaannya dalam projek Next.js anda!


Cara Menyediakan Zustand dalam Projek Next.js Anda

Ikuti langkah mudah ini untuk menyepadukan Zustand ke dalam apl Next.js anda.

1. Pasang Zustand

Jalankan arahan berikut untuk memasang Zustand:

npm i zustand

2. Buat Folder Kedai

Di dalam folder src anda, buat folder baharu bernama stor. Ini akan menyimpan semua fail keadaan Zustand anda.

src/
  store/
    index.ts
    userStore.ts

3. Tambah Kedai Anda

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 }),
}));

counterStore.ts (dengan berterusan)

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),
    }
  )
);

index.ts

Fail ini akan mengeksport semua kedai untuk import yang lebih mudah.

import { useUserStore } from "./userStore";
import { useCounterStore } from "./counterStore";

export { useUserStore, useCounterStore };

4. Menggunakan Zustand dalam Komponen

Berikut ialah contoh cara menggunakan stor Zustand dalam komponen Next.js anda.

Rumah.tsx

"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>
  );
}

Repositori Projek Permulaan ?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn