位置: IT常识 - 正文

React中useReducer的理解与使用(react usereducer)

编辑:rootadmin
React中useReducer的理解与使用

推荐整理分享React中useReducer的理解与使用(react usereducer),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:react use,react use,react useref和createref,react useref和createref,react userouter,react useref和createref,react usereducer,react usereducer,内容如对您有帮助,希望把文章链接给更多的朋友!

这里以简单的语言描述一下useReducer的使用。也可自己查看官方文档(英文)

useReducer的使用场景: 当一个state需要维护多个数据且它们之间互相依赖。 这样业务代码中只需要通过dispatch来更新state,繁杂的逻辑都在reducer函数中了。

一、useReducer

demo:

function reducer(state, action){ //...}const [state, dispatch] = useReducer(reducer, { name: "qingying", age: 18 });1. useReducer

主要作用就是更新state。

React中useReducer的理解与使用(react usereducer)

参数:

第一个是 reducer 函数,这个函数返回一个新的state。 后面再详述该函数的使用。第二个是 state 初始值。

返回值:

当前 state。(可以在业务代码中获取、操作的就是它。)dispatch 函数,纯函数,用来更新state,并会触发re-render。 (通俗地说,dispatch就是重新操作state的,会让组件重新渲染)2. reducer函数

作用:处理传入的state,并返回新的state。

参数:

接受当前 state。接受一个action,它是 dispatch 传入的。

返回值:

新的state。

3. dispatch函数

发送一个对象给reducer,即action。

参数: 一个对象。 返回值: 无。

完整代码:

import { useReducer } from "react";/* 当state需要维护多个数据且它们互相依赖时,推荐使用useReducer组件内部只是写dispatch({...})处理逻辑的在useReducer函数中。获取action传过来的值,进行逻辑操作*/// reducer计算并返回新的statefunction reducer(state, action) { const { type, nextName } = action; switch (type) { case "ADD": return { ...state, age: state.age + 1 }; case "NAME": return { ...state, name: nextName }; } throw Error("Unknown action: " + action.type);}export default function ReducerTest() { const [state, dispatch] = useReducer(reducer, { name: "qingying", age: 12 }); function handleInputChange(e) { dispatch({ type: "NAME", nextName: e.target.value }); } function handleAdd() { dispatch({ type: "ADD" }); } const { name, age } = state; return ( <> <input value={name} onChange={handleInputChange} /> <br /> <button onClick={handleAdd}>添加1</button> <p> Hello,{name}, your age is {age} </p> </> );}
本文链接地址:https://www.jiuchutong.com/zhishi/300187.html 转载请保留说明!

上一篇:【Node.js实战】一文带你开发博客项目(API 对接 MySQL)(node.js教程详细)

下一篇:SOC计算方法:卡尔曼滤波算法(sockas)

  • 小规模纳税人每月不超过10万
  • 税金及附加二级明细
  • 核定征收的计算方法有哪些
  • 企业筹建期间契税账务处理
  • 发票未到怎么暂估入账
  • 有限公司能否申请破产
  • 开发票时怎么操作收款人 复核人 开票人
  • 物流公司主营业务范围
  • 2020小规模纳税人印花税怎么算
  • 门店活动经费计入什么
  • 附加税减免税会计处理怎么做?
  • 企业将自用设备进行出租
  • 财产清查的种类有哪些
  • 建筑工程增值税税率是9还是11
  • 物业管理费什么时候交?
  • 企业所得税汇算清缴退税账务处理
  • 建筑行业劳务费开发票可以开工程款吗?
  • 建筑业简易征收的适用范围
  • 计提附加税的会计处理
  • 孵化器 怎么赚钱
  • 开票金额小于付款金额,怎么办理
  • 待处理流动资产损失属于什么科目
  • 以存货对外投资,现金流量表
  • 减少子公司合并的风险
  • 硬盘损坏类型
  • 教育培训行业收入
  • 认证超时什么意思
  • php 无限级分类
  • 如何显示或隐藏编辑标记
  • Tip是什么意思英语
  • 建筑单位没有资质可以承包项目吗
  • 多收不用退的货物怎么办
  • 零售环节的金银首饰需征收增值税吗
  • window7无法正常启动怎么办
  • uniapp自定义组件模式
  • 装修房子监理
  • 开发支出应属于什么科目
  • 旅游企业会计ppt
  • php统计目录中文怎么写
  • 政府给的土地补偿标准
  • 企业收到借款利息收入是否交增值税
  • 解决laravel 5.1报错:No supported encrypter found的办法
  • 即征即退增值税怎么申报
  • 比利牛斯山作为天然界限
  • php执行linux命令无效
  • 基于javaweb是什么意思
  • anaconda下的python
  • php5.6漏洞
  • 农产品收购发票是普票还是专票
  • 预收账款的账务处理摘要
  • 发票勾选认证具体流程
  • 单位收的房租可以发工资吗
  • mysql索引和主键
  • php网站访问量大怎么优化
  • 公司购入的发明产品
  • 增值税补充申报表不填可以吗
  • 长期待摊费用是非流动资产吗
  • 个税专项附加扣除标准2023
  • 所得税预缴怎么申报
  • 白条该如何处理好
  • 再保险责任的承担
  • 原材料贷方余额怎么转成本
  • 应收账款少收会计分录
  • 海关进口增值税专用缴款书在哪里打印
  • 开红字发票购买方和销货方有哪些操作不同?
  • xp系统 控制面板
  • 方正笔记本
  • 通过修改注册表修改edge主页
  • centos更新yum update
  • win10系统家庭组如何关闭家庭组访问用户名密码
  • 批处理加密工具
  • python 二叉树
  • TNet Tasharen Networking 学习总结
  • unity ui
  • javascript字符类型
  • 真机调试什么意思
  • 向境外付款需要代扣代缴所得税吗
  • 企业从国外进口铁矿石
  • 广州市税务局副局长陈忠文
  • 破产清算处置资产增值税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设