Heim >Web-Frontend >js-Tutorial >Zustandsverwaltung mit useContext und useReducer in React: Aufbau eines globalen Warenkorbs
Im vorherigen Artikel haben wir das Konzept der Kombination von useContext und useReducer vorgestellt, um den globalen Status in einer React-Anwendung effektiv zu verwalten. Wir haben dies demonstriert, indem wir eine einfache To-Do-Liste erstellt haben. Jetzt gehen wir einen Schritt weiter und wenden diese Konzepte auf ein komplexeres, reales Beispiel an – einen globalen Warenkorb.
In diesem Leitfaden erfahren Sie, wie Sie mehrere Status und Aktionen verwalten, z. B. das Hinzufügen, Aktualisieren und Entfernen von Elementen sowie das Berechnen von Gesamtsummen – und das alles unter Beibehaltung der Skalierbarkeit und Leistung der Anwendung.
In diesem zweiten Teil lernen Sie:
Lass uns eintauchen!
Unsere Warenkorbanwendung enthält:
Wir beginnen mit der Einrichtung des Kontexts und des Reduzierers und erstellen dann Komponenten, um die Funktionen zu präsentieren.
Um zu beginnen, initialisieren Sie Ihr React-Projekt und richten Sie eine grundlegende Ordnerstruktur ein:
src/ ├── CartContext.js ├── CartProvider.js ├── ProductList.js ├── Cart.js └── App.js
Wir beginnen mit einem Ausgangszustand, der einen leeren Warenkorb und eine Reihe von Beispielprodukten darstellt.
Anfangszustand:
// Initial state structure const initialState = { products: [ { id: 1, name: "Product A", price: 30 }, { id: 2, name: "Product B", price: 20 }, { id: 3, name: "Product C", price: 50 } ], cart: [], totalItems: 0, totalPrice: 0 };
Reduzierfunktion:
Wir richten eine CartReducer-Funktion ein, um verschiedene Aktionen wie das Hinzufügen von Artikeln, das Aktualisieren von Artikelmengen, das Entfernen von Artikeln und das Berechnen von Gesamtsummen durchzuführen.
src/ ├── CartContext.js ├── CartProvider.js ├── ProductList.js ├── Cart.js └── App.js
Jetzt erstellen wir einen Kontext und einen Anbieter, um unsere Status- und Versandfunktion global zu übergeben. Dadurch können alle Komponenten auf den Warenkorbstatus und die Aktionen zugreifen.
CartContext.js
// Initial state structure const initialState = { products: [ { id: 1, name: "Product A", price: 30 }, { id: 2, name: "Product B", price: 20 }, { id: 3, name: "Product C", price: 50 } ], cart: [], totalItems: 0, totalPrice: 0 };
Nachdem der Anbieter und der Kontext eingerichtet sind, können wir jetzt Komponenten für die Produktliste und den Warenkorb erstellen.
Die ProductList-Komponente zeigt eine Liste der verfügbaren Produkte an und ermöglicht Benutzern das Hinzufügen von Produkten zum Warenkorb.
ProductList.js
function cartReducer(state, action) { switch (action.type) { case "ADD_TO_CART": { const item = state.cart.find(item => item.id === action.payload.id); const updatedCart = item ? state.cart.map(cartItem => cartItem.id === item.id ? { ...cartItem, quantity: cartItem.quantity + 1 } : cartItem ) : [...state.cart, { ...action.payload, quantity: 1 }]; return { ...state, cart: updatedCart }; } case "REMOVE_FROM_CART": { const updatedCart = state.cart.filter(item => item.id !== action.payload); return { ...state, cart: updatedCart }; } case "UPDATE_QUANTITY": { const updatedCart = state.cart.map(item => item.id === action.payload.id ? { ...item, quantity: action.payload.quantity } : item ); return { ...state, cart: updatedCart }; } case "CALCULATE_TOTALS": { const { totalItems, totalPrice } = state.cart.reduce( (totals, item) => { totals.totalItems += item.quantity; totals.totalPrice += item.price * item.quantity; return totals; }, { totalItems: 0, totalPrice: 0 } ); return { ...state, totalItems, totalPrice }; } default: return state; } }
Die Warenkorbkomponente zeigt Artikel im Warenkorb an, ermöglicht das Aktualisieren von Mengen, das Entfernen von Artikeln und zeigt die Gesamtzahl der Artikel und den Preis an.
Cart.js
import React, { createContext, useReducer } from 'react'; export const CartContext = createContext(); export function CartProvider({ children }) { const [state, dispatch] = useReducer(cartReducer, initialState); return ( <CartContext.Provider value={{ state, dispatch }}> {children} </CartContext.Provider> ); }
Um sicherzustellen, dass alle Komponenten auf den Warenkorbstatus zugreifen können, schließen Sie die gesamte App in CartProvider ein.
App.js
import React, { useContext } from 'react'; import { CartContext } from './CartContext'; function ProductList() { const { state, dispatch } = useContext(CartContext); const handleAddToCart = (product) => { dispatch({ type: "ADD_TO_CART", payload: product }); dispatch({ type: "CALCULATE_TOTALS" }); }; return ( <div> <h2>Products</h2> <ul> {state.products.map(product => ( <li key={product.id}> {product.name} - ${product.price} <button onClick={() => handleAddToCart(product)}>Add to Cart</button> </li> ))} </ul> </div> ); } export default ProductList;
Wenn Ihre Anwendung wächst, ist die Optimierung der Leistung von entscheidender Bedeutung. Hier ein paar Tipps:
In dieser erweiterten Anleitung haben wir useContext und useReducer verwendet, um einen globalen Warenkorb zu verwalten. Zu den wichtigsten Erkenntnissen gehören:
Versuchen Sie, diesen Ansatz auf Ihre Projekte anzuwenden, und sehen Sie, wie er die Skalierbarkeit und Leistung Ihrer Anwendungen verbessert. Viel Spaß beim Codieren! ?
Das obige ist der detaillierte Inhalt vonZustandsverwaltung mit useContext und useReducer in React: Aufbau eines globalen Warenkorbs. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!