React での状態管理がこれほど簡単かつ軽量になったことはありません。 Zustand は小さいながらも強力な状態管理ライブラリで、開発者の作業を大幅に楽にしてくれます。 Redux の定型文や Context API の制限にうんざりしている場合でも、Zustand がその窮地を救ってくれます。
この投稿では、Zustand を紹介し、私が構築した スターター プロジェクト を共有します。GitHub で入手できます。手順に従って、わずか数ステップで Next.js プロジェクトで Zustand を使い始めましょう。 ?
ズスタンドとは何ですか? ?
Zustand (ドイツ語で「状態」の意味) は、React 用の最小限の状態管理ライブラリです。それは以下を提供します:
- 非常にシンプルな API。
- 不必要な再レンダリングのない高いパフォーマンス。
- わかりやすい構文。
- 組み込みミドルウェアのサポート (状態の永続化など)。
それでは、Next.js プロジェクトでの設定を見ていきましょう!
Next.js プロジェクトで Zustand をセットアップする方法
次の簡単な手順に従って、Zustand を Next.js アプリに統合します。
1.ズスタンドをインストールする
次のコマンドを実行して Zustand をインストールします:
npm i zustand
2. 保存フォルダーを作成する
src フォルダー内に、store という名前の新しいフォルダーを作成します。これには、すべての Zustand 状態ファイルが保持されます。
src/ store/ index.ts userStore.ts
3. ストアを追加する
userStore.ts
このストアはユーザー関連のデータを処理します。
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 }), })); </userstore>
counterStore.ts (永続化あり)
このストアはカウンター状態を処理し、それを 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), } ) ); </icounterstore>
index.ts
このファイルは、インポートを容易にするためにすべてのストアをエクスポートします。
import { useUserStore } from "./userStore"; import { useCounterStore } from "./counterStore"; export { useUserStore, useCounterStore };
4. コンポーネントでの Zustand の使用
Next.js コンポーネントで Zustand ストアを使用する方法の例を次に示します。
ホーム.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 classname="p-2 border" href="/about">About <link classname="p-2 border" href="/contact">Contact </div> <h1 id="Hello">Hello</h1> <h1 id="User-userStore-user-email">User: {userStore.user?.email}</h1> <button classname="bg-blue-500 rounded-md p-2 text-white" onclick="{handleAddUser}"> Add User </button> <br> <h1 id="Counter-counterStore-counter">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> ); }
スターター プロジェクト リポジトリ ?
この スターター プロジェクト の完全なコードは GitHub で入手できます。初心者向けで、Next.js で Zustand の使用を開始するために必要なものがすべて含まれています。
リポジトリのクローンを作成して開始します:
git clone https://github.com/MiladJoodi/Zustand_Starter_Project.git cd Zustand_Starter_Project npm install npm run dev
Zustand を使って簡単に状態の管理を始めましょう。ご意見をお聞かせください。または、ご自身の使用例も共有してください。 ?
以上が最も簡単な方法で今すぐ Zustand を学びましょう!の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptコアデータ型は、ブラウザとnode.jsで一貫していますが、余分なタイプとは異なる方法で処理されます。 1)グローバルオブジェクトはブラウザのウィンドウであり、node.jsのグローバルです2)バイナリデータの処理に使用されるNode.jsの一意のバッファオブジェクト。 3)パフォーマンスと時間の処理にも違いがあり、環境に従ってコードを調整する必要があります。

javascriptusestwotypesofcomments:シングルライン(//)およびマルチライン(//)

PythonとJavaScriptの主な違いは、タイプシステムとアプリケーションシナリオです。 1。Pythonは、科学的コンピューティングとデータ分析に適した動的タイプを使用します。 2。JavaScriptは弱いタイプを採用し、フロントエンドとフルスタックの開発で広く使用されています。この2つは、非同期プログラミングとパフォーマンスの最適化に独自の利点があり、選択する際にプロジェクトの要件に従って決定する必要があります。

PythonまたはJavaScriptを選択するかどうかは、プロジェクトの種類によって異なります。1)データサイエンスおよび自動化タスクのPythonを選択します。 2)フロントエンドとフルスタック開発のためにJavaScriptを選択します。 Pythonは、データ処理と自動化における強力なライブラリに好まれていますが、JavaScriptはWebインタラクションとフルスタック開発の利点に不可欠です。

PythonとJavaScriptにはそれぞれ独自の利点があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1. Pythonは、データサイエンスやバックエンド開発に適した簡潔な構文を備えた学習が簡単ですが、実行速度が遅くなっています。 2。JavaScriptはフロントエンド開発のいたるところにあり、強力な非同期プログラミング機能を備えています。 node.jsはフルスタックの開発に適していますが、構文は複雑でエラーが発生しやすい場合があります。

javascriptisnotbuiltoncorc;それは、解釈されていることを解釈しました。

JavaScriptは、フロントエンドおよびバックエンド開発に使用できます。フロントエンドは、DOM操作を介してユーザーエクスペリエンスを強化し、バックエンドはnode.jsを介してサーバータスクを処理することを処理します。 1.フロントエンドの例:Webページテキストのコンテンツを変更します。 2。バックエンドの例:node.jsサーバーを作成します。

PythonまたはJavaScriptの選択は、キャリア開発、学習曲線、エコシステムに基づいている必要があります。1)キャリア開発:Pythonはデータサイエンスとバックエンド開発に適していますが、JavaScriptはフロントエンドおよびフルスタック開発に適しています。 2)学習曲線:Python構文は簡潔で初心者に適しています。 JavaScriptの構文は柔軟です。 3)エコシステム:Pythonには豊富な科学コンピューティングライブラリがあり、JavaScriptには強力なフロントエンドフレームワークがあります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

WebStorm Mac版
便利なJavaScript開発ツール
