Die Statusverwaltung in React war noch nie so einfach und leicht! Lernen Sie Zustand kennen, eine kleine, aber leistungsstarke Zustandsverwaltungsbibliothek, die Ihnen das Leben als Entwickler erheblich erleichtern wird. Egal, ob Sie die Standardfunktionen von Redux oder die Einschr?nkungen der Kontext-API satt haben, Zustand ist hier, um den Tag zu retten.
In diesem Beitrag stelle ich Zustand vor und teile ein Starterprojekt, das ich erstellt habe und das auf GitHub verfügbar ist. Folgen Sie uns, um in nur wenigen Schritten mit Zustand in einem Next.js-Projekt zu beginnen! ?
Was ist Zustand? ?
Zustand (deutsch für ?Zustand“) ist eine minimalistische Zustandsverwaltungsbibliothek für React. Es bietet:
- Eine supereinfache API.
- Hohe Leistung ohne unn?tiges erneutes Rendern.
- Leicht verst?ndliche Syntax.
- Integrierte Middleware-Unterstützung (z. B. für den persistenten Zustand).
Lassen Sie uns nun mit der Einrichtung in Ihrem Next.js-Projekt beginnen!
So richten Sie Zustand in Ihrem Next.js-Projekt ein
Befolgen Sie diese einfachen Schritte, um Zustand in Ihre Next.js-App zu integrieren.
1. Zustand installieren
Führen Sie den folgenden Befehl aus, um Zustand zu installieren:
npm i zustand
2. Erstellen Sie einen Store-Ordner
Erstellen Sie in Ihrem src-Ordner einen neuen Ordner mit dem Namen ?store“. Hier werden alle Ihre Zustandsdateien gespeichert.
src/ store/ index.ts userStore.ts
3. Fügen Sie Ihre Gesch?fte hinzu
userStore.ts
Dieser Shop verarbeitet benutzerbezogene Daten.
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 (mit Persistenz)
Dieser Store verarbeitet einen Z?hlerstand und speichert ihn im 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
Diese Datei exportiert alle Gesch?fte für einfachere Importe.
import { useUserStore } from "./userStore"; import { useCounterStore } from "./counterStore"; export { useUserStore, useCounterStore };
4. Verwendung von Zustand in Komponenten
Hier ist ein Beispiel für die Verwendung von Zustandsspeichern in Ihren Next.js-Komponenten.
Home.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> ); }
Starter-Projekt-Repository?
Der vollst?ndige Code für dieses Starterprojekt ist auf GitHub verfügbar. Es ist einsteigerfreundlich und enth?lt alles, was Sie brauchen, um Zustand mit Next.js zu verwenden.
Klonen Sie das Repository und legen Sie los:
git clone https://github.com/MiladJoodi/Zustand_Starter_Project.git cd Zustand_Starter_Project npm install npm run dev
Verwalten Sie Ihren Zustand mühelos mit Zustand. Teilen Sie mir Ihre Meinung mit oder teilen Sie mir Ihre eigenen Anwendungsf?lle mit! ?
Das obige ist der detaillierte Inhalt vonLernen Sie Zustand jetzt auf einfachste Weise!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

JavaScriptisidealforwebDevelopment, w?hrend JavasuitSlarge-ScaleApplications-und-und -entwicklung.1) JavascriptexcelsincreatinginteractiveWebexperiencesandful-StackDevelopmentwitHnode.js.2) javaisroboBusthernprispribies

In JavaScript h?ngt die Auswahl eines Einzelzeilen-Kommentars (//) oder eines Mehrzeilungskommentars (//) von den Zweck- und Projektanforderungen des Kommentars ab: 1. Verwenden Sie Einzelzeilen-Kommentare für eine schnelle und Inline-Interpretation; 2. Verwenden Sie Multi-Line-Kommentare für detaillierte Dokumentation. 3.. Behalten Sie die Konsistenz des Kommentarstils bei; 4. Vermeiden Sie überankünfte; 5. Stellen Sie sicher, dass die Kommentare synchron mit dem Code aktualisiert werden. Die Auswahl des richtigen Annotationsstils kann dazu beitragen, die Lesbarkeit und Wartbarkeit Ihres Codes zu verbessern.

Ja, JavaScriptComents isten -n?tig und schuldiert, 1) sie haben sich entwickeln, die Codelogicandintent, 2) ArevitalIncomplexProjects und 3) ShoeNeClarity Gloutclutterthecode.

Java und JavaScript sind unterschiedliche Programmiersprachen, die jeweils für verschiedene Anwendungsszenarien geeignet sind. Java wird für die Entwicklung gro?er Unternehmen und mobiler Anwendungen verwendet, w?hrend JavaScript haupts?chlich für die Entwicklung von Webseiten verwendet wird.

JavaScriptComents AreseessentialFormaintaining, Lesen und GuidingCodeexexecution.1) einzelne Linecommments Arequickickexplanationen.2) Multi-LindexplainComproxlogicorProvedetailedDocumentation.3) InlinecommentsclarifyspecificPartsosensofCode.BestPracticic

CommentareAtecrucialinjavaScriptFormaintainingClarity und FosteringCollaboration.1) thehelpindebugging, Onboarding, und die Verst?rkung vonCodeevolution.2) Verwendungsle-Linien- und Verst??en für FosterquickexPlanations und Multi-LinecomMentSfordsetaileddescriptions.3) Bestpraktiziert

JavascripThasseveralprimitedatatypes: Zahl, String, Boolean, undefined, Null, Symbol und Bigint und Non-Primitivetypes LikeObjectandArray.Ververst?ndnisTheSeisScricialForwritingEffiction, Bug-Freecode: 1) numberusesa64-Bitformat, führend, führend, führend, pointofointofloatieren-pointoinssli

JavaScriptispreferredforwebdevelopment,whileJavaisbetterforlarge-scalebackendsystemsandAndroidapps.1)JavaScriptexcelsincreatinginteractivewebexperienceswithitsdynamicnatureandDOMmanipulation.2)Javaoffersstrongtypingandobject-orientedfeatures,idealfor
