返回顶部
c

cart-management购物车管理

React cart state management: duplicate prevention, localStorage persistence, CartContext patterns. Use when building or fixing shopping carts, product lists, or cart-related UI.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
561
下载量
免费
免费
0
收藏
概述
安装方式
版本历史

cart-management

购物车管理技能

React购物车状态模式:重复预防、持久化、上下文设计。

重复预防

  • - 在CartContext中跟踪产品ID(独立状态或从cartItems派生)
  • 在添加前检查productIdsInCart.includes(item.id)
  • 将逻辑集中在上下文中,而非ProductCard或子组件中

持久化(localStorage)

  • - 挂载时从localStorage.getItem(cart)初始化购物车状态
  • 每次添加/移除时持久化:localStorage.setItem(cart, JSON.stringify(cartItems))
  • 如果使用productIdsInCart则同步:localStorage.setItem(cart_ids, JSON.stringify(ids))
  • 防止跨会话重复(刷新、新标签页)

CartContext模式

tsx
const addToCart = (item: CartItem) => {
if (!productIdsInCart.includes(item.id)) {
setCartItems(prev => [...prev, item]);
setProductIdsInCart(prev => [...prev, item.id]);
localStorage.setItem(cart, JSON.stringify([...cartItems, item]));
}
};

反模式

  • - 不要在ProductCard挂载时的useEffect中添加购物车(会导致重复)
  • 不要在多个组件中重复逻辑——使用上下文
  • 添加后端验证作为数据完整性的后备方案

数量更新

对于相同产品的数量:使用cartItems.map()更新item.quantity,不要创建重复条目。

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 cart-management-1776419963 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 cart-management-1776419963 技能

通过命令行安装

skillhub install cart-management-1776419963

下载

⬇ 下载 cart-management v1.0.0(免费)

文件大小: 1.33 KB | 发布时间: 2026-4-17 20:18

v1.0.0 最新 2026-4-17 20:18
Initial release: provides robust patterns for React cart state management.

- Prevents duplicate cart entries using product ID tracking in CartContext.
- Persists cart state and product IDs in localStorage for session durability.
- Centralizes add/remove logic within CartContext for maintainability.
- Includes clear anti-patterns and recommendations for quantity management.
- Designed for reuse in shopping carts, product lists, or cart-related UIs.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部