位置: 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)

  • 长期待摊费用一般指什么
  • 工商年报资产状况纳税总额怎么计算?
  • 建筑业项目在外地在哪里交增值税
  • 外国常驻代表机构办理税务登记
  • 营业执照丢失公示几天才能注销
  • 合并两公司的帐务怎么做
  • 收据盖公章要注意哪些
  • 红字信息表能开多少行
  • 负数增长到正数的例子
  • 会计凭证有哪些类型
  • 摊销直线法会计分录怎么写?
  • 变更企业性质企业怎么办
  • 交通费补贴报销的会计分录怎么做?
  • 超市送现金券怎么做账
  • 增值税附加税计入什么会计科目
  • 企事业承包承租方缴纳的管理费税费
  • 企业牌照拍卖收入计入什么科目
  • 处置子公司合并抵消
  • 经营性流动负债计算公式
  • 企业雇佣临时工的工资属于工资薪金支出么
  • 即期结售汇期限包括
  • PHP:mcrypt_ecb()的用法_Mcrypt函数
  • 免征的增值税账务处理
  • 企业购入固定资产要交印花税吗
  • 留抵税额进项构成比例
  • 车辆保养费可以计入交通费吗
  • 残保金所属期怎么写
  • vue table导出excel
  • meta最新模型
  • tune a video:one-shot tuning of image diffusion models for text-to-video generation
  • pytorch广播相乘
  • wordpress安装包
  • 超市账目月底怎么核算
  • input和printf的区别
  • 帝国cms采集教程
  • 企业印花税怎么入账
  • 残疾人保障金所属期怎么填
  • 个人所得税分摊方式怎么填
  • 印花税计税依据怎么算
  • 当月开的票必须开发票吗
  • 一般纳税人收到的普票可以抵扣吗
  • 物业公司收的停车费做什么科目
  • 所得税的汇算清缴日在资产负债表日后期间
  • 应收分保未到期责任准备金是什么科目
  • 企业从银行取得短期贷款存入银行,属于( )类型变化业务
  • 已认证进项税转出口退税怎么处理
  • 销售给回扣的话术
  • 税务局返还税款账务处理
  • 超过社保基数的工资怎么发放
  • 土地无形资产摊销的会计处理方法
  • 房屋租赁产生的税费叫什么
  • 金蝶软件标准版多少
  • 利润表增加,资产负债表减少怎么回事
  • mysql分页时offset过大的Sql优化经验分享
  • mysql如何跨库查询
  • 操作系统运行慢怎么解决
  • 安装win8.1系统步骤
  • window8系统安装步骤
  • safeplugin是什么软件
  • 苹果电脑打不开txt
  • nmeo.exe是什么
  • ssh直接输入密码 linux
  • python中的is和==的区别
  • listview设置item宽度
  • Unity3D之Transform参数
  • IE8 新增的Javascript 开发接口说明
  • PYTHON内置函数,标准库,三方库的区别
  • javascript含义
  • js合并字符串
  • 今天百度汉语
  • python系统代码
  • android 系统app开机自启动设置
  • 企业破产享有的债权可否提前到期
  • 浙江省电税务局电话
  • 个人所得税票样
  • 原木进项税率
  • 航天金穗280怎么入账
  • 报税日期2023年
  • 如何查询房屋契税是否退还
  • 税务筹划前景
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设