前端状态管理:Recoil的原子世界

前端状态管理:Recoil的原子世界

毒舌时刻

前端状态管理?Redux不是已经够了吗?

"Redux太复杂了,我用Context API就够了"——结果状态管理混乱,性能差,
"Zustand简单,我用Zustand"——结果复杂状态难以管理,
"Recoil?没听说过,肯定不如Redux"——结果错过了更优雅的状态管理方案。

醒醒吧,Recoil不是Redux的替代品,而是一种更现代化的状态管理方案!

为什么你需要这个?

  • 原子化状态:将状态拆分为最小的原子单位,更灵活
  • 派生状态:通过选择器创建派生状态,减少重复计算
  • React集成:与React Hooks无缝集成,使用更自然
  • 性能优化:只重新渲染依赖状态变化的组件

反面教材

// 反面教材:使用Context API管理复杂状态 import React, { createContext, useContext, useState, useReducer } from 'react'; // 创建Context const AppContext = createContext(); // 复杂的reducer function reducer(state, action) { switch (action.type) { case 'SET_USER': return { ...state, user: action.payload }; case 'SET_TODOS': return { ...state, todos: action.payload }; case 'ADD_TODO': return { ...state, todos: [...state.todos, action.payload] }; case 'TOGGLE_TODO': return { ...state, todos: state.todos.map(todo => todo.id === action.payload ? { ...todo, completed: !todo.completed } : todo ) }; // 更多action... default: return state; } } // Provider组件 function AppProvider({ children }) { const [state, dispatch] = useReducer(reducer, { user: null, todos: [], loading: false, error: null }); return ( <AppContext.Provider value={{ state, dispatch }}> {children} </AppContext.Provider> ); } // 使用Context function TodoList() { const { state, dispatch } = useContext(AppContext); // 每次状态变化都会重新渲染,即使只关心todos return ( <div> {state.todos.map(todo => ( <div key={todo.id}> <input type="checkbox" checked={todo.completed} onChange={() => dispatch({ type: 'TOGGLE_TODO', payload: todo.id })} /> {todo.text} </div> ))} </div> ); } 

正确的做法

// 正确的做法:使用Recoil import React from 'react'; import { atom, selector, useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil'; // 定义原子状态 const userState = atom({ key: 'userState', default: null }); const todosState = atom({ key: 'todosState', default: [] }); const loadingState = atom({ key: 'loadingState', default: false }); // 定义派生状态 const completedTodosState = selector({ key: 'completedTodosState', get: ({ get }) => { const todos = get(todosState); return todos.filter(todo => todo.completed); } }); const incompleteTodosState = selector({ key: 'incompleteTodosState', get: ({ get }) => { const todos = get(todosState); return todos.filter(todo => !todo.completed); } }); const todoStatsState = selector({ key: 'todoStatsState', get: ({ get }) => { const todos = get(todosState); const completed = get(completedTodosState); const incomplete = get(incompleteTodosState); return { total: todos.length, completed: completed.length, incomplete: incomplete.length, completionRate: todos.length > 0 ? (completed.length / todos.length) * 100 : 0 }; } }); // 使用Recoil状态 function TodoList() { // 只订阅todosState,其他状态变化不会触发重新渲染 const [todos, setTodos] = useRecoilState(todosState); const toggleTodo = (id) => { setTodos(todos.map(todo => todo.id === id ? { ...todo, completed: !todo.completed } : todo )); }; return ( <div> {todos.map(todo => ( <div key={todo.id}> <input type="checkbox" checked={todo.completed} onChange={() => toggleTodo(todo.id)} /> {todo.text} </div> ))} </div> ); } function TodoStats() { // 只订阅派生状态,当依赖的状态变化时才会重新渲染 const stats = useRecoilValue(todoStatsState); return ( <div> <p>总任务数:{stats.total}</p> <p>已完成:{stats.completed}</p> <p>未完成:{stats.incomplete}</p> <p>完成率:{stats.completionRate.toFixed(2)}%</p> </div> ); } function AddTodo() { // 只订阅setter函数,不会因为状态变化而重新渲染 const setTodos = useSetRecoilState(todosState); const [text, setText] = React.useState(''); const handleSubmit = (e) => { e.preventDefault(); if (text.trim()) { setTodos(prev => [...prev, { id: Date.now(), text, completed: false }]); setText(''); } }; return ( <form onSubmit={handleSubmit}> <input type="text" value={text} onChange={(e) => setText(e.target.value)} placeholder="添加任务" /> <button type="submit">添加</button> </form> ); } function UserProfile() { const [user, setUser] = useRecoilState(userState); const [loading, setLoading] = useRecoilState(loadingState); React.useEffect(() => { setLoading(true); // 模拟API请求 setTimeout(() => { setUser({ id: 1, name: '张三', email: '[email protected]' }); setLoading(false); }, 1000); }, [setUser, setLoading]); if (loading) { return <div>加载中...</div>; } return ( <div> <h2>用户信息</h2> {user ? ( <div> <p>姓名:{user.name}</p> <p>邮箱:{user.email}</p> </div> ) : ( <p>未登录</p> )} </div> ); } // 主应用 function App() { return ( <div> <h1>Recoil状态管理示例</h1> <UserProfile /> <AddTodo /> <TodoList /> <TodoStats /> </div> ); } 

毒舌点评

看看,这才叫前端状态管理!不是简单地使用Context API或Redux,而是使用Recoil的原子化状态管理,让状态管理更加清晰和高效。

记住,Recoil的优势在于它的原子化和派生状态,这使得状态管理更加灵活和可扩展。它与React Hooks的无缝集成,让使用起来更加自然。

所以,别再固守传统的状态管理方案了,Recoil为你打开了一个全新的原子世界!

总结

  • 原子状态:使用atom定义最小的状态单位
  • 派生状态:使用selector创建基于原子状态的派生状态
  • React集成:使用useRecoilStateuseRecoilValueuseSetRecoilState等Hooks
  • 性能优化:只重新渲染依赖状态变化的组件
  • 状态持久化:可以与localStorage等结合实现状态持久化
  • 调试工具:使用Recoil DevTools进行状态调试
  • 类型支持:完整的TypeScript类型支持
  • 可扩展性:适合从小型应用到大型应用的各种场景

Recoil,让前端状态管理变得更加优雅!

Read more

OpenClaw 完整部署指南:安装 + 三大 Coding Plan 配置 + CC Switch + 飞书机器人

OpenClaw 完整部署指南:安装 + 三大 Coding Plan 配置 + CC Switch + 飞书机器人

OpenClaw 完整部署指南:安装 + 三大 Coding Plan 配置 + CC Switch + 飞书机器人 * 📋 文章目录结构 * 1.3 一键安装 OpenClaw(推荐) * 1.4 通过 npm 手动安装 * 1.5 运行 Onboard 向导 * 1.6 验证安装 * 步骤二:配置 Coding Plan 模型 * 🅰️ 选项 A:阿里百炼 Coding Plan * A.1 订阅与获取凭证 * A.2 在 OpenClaw 中配置 * A.3 可用模型列表

Java 大视界 -- Java 大数据在智能家居能源消耗趋势预测与节能策略优化中的应用(433)

Java 大视界 -- Java 大数据在智能家居能源消耗趋势预测与节能策略优化中的应用(433)

Java 大视界 -- Java 大数据在智能家居能源消耗趋势预测与节能策略优化中的应用(433) * 引言: * 正文: * 一、智能家居能源管理的核心痛点与 Java 大数据的价值 * 1.1 行业核心痛点(基于《2024 中国智能家居行业白皮书》) * 1.2 Java 大数据的核心价值(实战验证适配性) * 二、技术架构设计实战(纵向架构图) * 2.1 核心技术栈选型(生产压测验证版) * 2.2 关键技术亮点(博主实战总结) * 三、核心场景实战(附完整可运行代码) * 3.1 场景一:能耗趋势预测(线性回归 + LSTM 融合模型) * 3.1.1 业务需求 * 3.1.

Rokid 手势识别技术深度解析:解锁 AR 无接触交互的核心秘密

Rokid 手势识别技术深度解析:解锁 AR 无接触交互的核心秘密

引言 在聊手势识别前,咱们先搞清楚:Rokid是谁?它为啥能把AR手势做得这么自然? Rokid是国内AR(增强现实)领域的“老兵”了,从2014年成立就盯着一个目标——让AR走进日常。你可能见过它的产品:能戴在脸上的“AR眼镜”Max Pro、能揣在兜里的“AR主机”Station 2、适合专业场景的“Station Pro”,这些设备不是用来“炫技”的,而是想让咱们摆脱手机、手柄的束缚,直接用手“摸”虚拟东西。 而手势识别,就是Rokid给AR设备装的“最自然的遥控器”——比如调大虚拟屏幕像捏橡皮一样捏合手指,翻页像翻书一样挥手。但不同设备、不同开发需求,需要搭配不同版本的SDK(软件开发工具包),这就像“不同型号的手机要装对应版本的APP”。 一、基础认知:先选对版本,避免开发走弯路 Rokid手势识别技术随SDK版本迭代持续优化,不同版本适配的Unity(开发工具)

基于深度学习YOLO算法+qwen deepseek大模型的无人机河道巡检系统平台 支持AI对话与文档生成分析

基于深度学习YOLO算法+qwen deepseek大模型的无人机河道巡检系统平台 支持AI对话与文档生成分析

YOLO+DeepSeek河道环境检测系统 项目简介 基于改进YOLO深度学习模型与DeepSeek大语言模型的河道环境智能检测与分析系统。本系统采用先进的计算机视觉技术,结合自然语言处理能力,实现对河道环境中各类目标的高精度检测与智能分析。系统支持单张图片、批量图片、视频文件及实时摄像头等多种输入方式,提供从环境检测到智能建议的完整解决方案,为河道治理、环境保护与水资源管理提供智能化技术支持。 ✨ 核心亮点 • 多场景检测支持:全面覆盖单张图片、图片文件夹、视频文件、实时摄像头四种输入方式 • 改进YOLO模型:基于YOLOv5/v8/v11/v12的优化版本,专注河道环境目标检测 • AI智能分析:集成DeepSeek/Qwen大模型,生成专业的河道环境分析与治理建议 • 实时处理反馈:前端实时展示检测进度与结果,支持实时视频流处理 • 完整技术栈:PyTorch深度学习 + SpringBoot后端 + Vue3前端 + Flask中台的完整架构 • 开箱即用:提供完整源码、预训练模型与详细部署文档,快速上手使用 🌊 检测对象范围 系统可精准识别河道