news 2026/4/18 11:23:21

react中useReducer的使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
react中useReducer的使用
// 导入React核心库及所需的类型和Hooks // FC: FunctionComponent 函数组件类型,用于约束组件类型 // useReducer: 用于复杂状态管理的Hook,替代useState处理多状态/复杂逻辑 // useState: 基础状态管理Hook(本示例未实际使用,保留导入仅作参考) import React, { FC, useReducer, useState } from 'react' /** * 定义状态的类型接口 * 约束useReducer中state的结构,确保类型安全 */ type StateType = { // 计数数值,核心状态字段 count: number } /** * 定义动作的类型接口 * 约束dispatch派发的action对象结构 */ type ActionType = { // 动作类型标识,用于reducer中区分不同操作 type: string // 若需要传递额外数据,可扩展该接口,例如:payload?: any } /** * 初始化状态值 * 作为useReducer的初始状态,定义count的初始值为100 */ const initialState: StateType = { count: 100 } /** * Reducer函数:纯函数,负责根据action更新状态 * 核心原则:不可变数据,返回新的state对象而非修改原对象 * @param state 当前状态(更新前的状态) * @param action 派发的动作对象,包含type标识 * @returns 新的状态对象(必须与StateType类型匹配) */ function reducer(state: StateType, action: ActionType) { // 根据action.type区分不同的状态更新逻辑 switch (action.type) { // 处理计数增加的动作 case 'increment': // 返回新状态:count在原有基础上加1 return { count: state.count + 1 } // 处理计数减少的动作 case 'decrement': // 返回新状态:count在原有基础上减1 return { count: state.count - 1 } // 处理未知动作类型,抛出错误提示 default: throw new Error(`未匹配到action类型: ${action.type}`) } } /** * 计数组件:使用useReducer管理计数状态 * FC类型约束:确保组件符合React函数组件的规范 */ const CountReducer: FC = () => { // 使用useReducer Hook创建状态和派发动作的方法 // 参数1: reducer函数(处理状态更新逻辑) // 参数2: initialState(初始状态) // 返回值: // state: 当前最新的状态对象(类型为StateType) // dispatch: 派发动作的函数,用于触发状态更新 const [state, dispatch] = useReducer(reducer, initialState) return ( // 片段标签:无需额外DOM节点包裹子元素 <> {/* 展示当前计数数值:从state中读取count */} <span>count:{state.count}</span> {/* 增加按钮:点击时派发increment类型的动作 */} <button onClick={() => dispatch({ type: 'increment' })} > + </button> {/* 减少按钮:点击时派发decrement类型的动作 */} <button onClick={() => dispatch({ type: 'decrement' })} > - </button> </> ) } // 导出组件,供其他模块导入使用 export default CountReducer

关键注释说明:

1. 类型定义:清晰标注StateType和ActionType的作用,约束状态和动作的结构,体现 TypeScript 的类型安全特性。

2. Reducer 函数:重点说明纯函数特性、不可变数据原则,以及每个 case 分支的作用。

3. useReducer 使用:解释 Hook 的参数和返回值,明确state(当前状态)和dispatch(动作派发函数)的含义。

4. UI 交互:标注按钮点击事件中dispatch的作用,说明如何通过派发不同类型的动作触发状态更新。

5. 代码结构:注释片段标签、导出语句等细节,帮助理解 React 组件的基本结构。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:57:07

OpenAI绝地反击:GPT-5.2紧急上线,以“最强职场模型”硬刚Gemini 3

【摘要】OpenAI紧急发布GPT-5.2&#xff0c;精准定位“最强职场模型”&#xff0c;以应对谷歌Gemini 3的竞争压力。此举标志着AI从通用助手向深度赋能专业工作流的生产力工具演进。引言AI领域的竞争节奏正在以超乎想象的速度加快。距离上一代模型发布不足一月&#xff0c;OpenA…

作者头像 李华
网站建设 2026/4/18 5:35:14

超细致的性能测试流程,你get了吗?

性能测试&#xff1a;利用工具模拟大量用户操作&#xff0c;验证系统承受的负载情况。 性能测试的目的&#xff1a;找到潜在的性能问题或瓶颈&#xff0c;分析并解决&#xff1b;找出性能变化趋势&#xff0c;为后续扩展系统提供参考。 测试监控&#xff1a;基准测试、配置测…

作者头像 李华
网站建设 2026/4/17 8:35:18

TorchAO完整指南:掌握量化与稀疏化技术快速提升AI模型性能

TorchAO完整指南&#xff1a;掌握量化与稀疏化技术快速提升AI模型性能 【免费下载链接】ao Native PyTorch library for quantization and sparsity 项目地址: https://gitcode.com/GitHub_Trending/ao2/ao 想要让你的PyTorch模型运行更快、占用更少资源吗&#xff1f;T…

作者头像 李华
网站建设 2026/4/18 4:25:12

云端算力:数字时代的核心引擎与创新基石

云端算力&#xff1a;数字时代的核心引擎与创新基石在数字经济加速渗透的今天&#xff0c;云端算力正以不可逆转的趋势重塑产业格局。从AI大模型训练到工业互联网实时分析&#xff0c;从元宇宙场景构建到全球科研协作&#xff0c;云端算力已成为驱动技术突破、产业升级与社会进…

作者头像 李华
网站建设 2026/4/18 4:30:29

Day33 类的装饰器

知识点&#xff1a; 1.类的装饰器 2.装饰器思想的进一步理解&#xff1a;外部修改、动态 3.类方法的定义&#xff1a;内部定义和外部定义 浙大疏锦行

作者头像 李华
网站建设 2026/4/18 2:09:11

Windows11系统文件themeui.dll损坏的情况 下载修复

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华