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

  • 收到政府的补贴收入现金流量表填哪里
  • 拟上市企业需要做什么
  • 个体工商户怎么注销
  • 保本理财收益计入什么科目
  • 资产负债表本月期末余额怎么填
  • 资产总额和权益总额必然相等吗
  • 幼儿园伙食收支盈亏比例
  • 车辆购置税完税证明网上打印
  • 用友怎么结转本期损益
  • 可转换公司债券权益成分和负债成分
  • 冲减往年管理费用
  • 有限公司跟股份有限公司的区别
  • 财产租赁合同印花税优惠政策
  • 固定资产原值减少账务处理
  • 工程服务预交税款怎么账务处理?
  • 如何理解出口退税政策
  • 税金及附加与期间费用区别
  • 汽油费能计入办公费吗
  • 公积金抵扣个税上限
  • 水利行政事业性收费收入会计分录
  • 2020年外资企业
  • 金融行业小规模纳税人税率
  • 小规模免增值税印花税用交吗
  • 法人可以公司账户存款吗
  • 生育津贴还扣税吗
  • 苹果mac有hdmi
  • 企业招聘费用计算公式
  • 打开浏览器时间长
  • linux开启远程ssh
  • 非货币性资产交换和债务重组的区别
  • 苹果macOS Big Sur 11.0.1全新系统壁纸
  • hpp是什么文件
  • 马哈拉施特拉邦人口
  • javascript基础语法
  • php数组函数题目
  • php常用类
  • hive dt
  • 利润表用处
  • 织梦cms要钱吗
  • 建筑企业其他应付款包含什么内容
  • 什么情况下提供个人征信
  • 一般纳税人作废发票的流程
  • sql server怎么创建约束
  • 发票已开不确认收入可以做吗?
  • 金税四期对企业的好处
  • 白条抵库现象
  • 商贸公司用购进产品吗
  • 直接减免增值税的情形
  • 管理费用如何冲减
  • 分包管理费取费标准
  • 做账财务费用负数
  • 发票联遗失的证明怎么开
  • 怎样贴发票之类的报销单据
  • 公司法人借款给公司用责任承担
  • 费用报销单人民币符号
  • 计提房产税需要附凭证吗
  • 商业会计和工业会计哪个好
  • 临时工工资怎么入账合法吗
  • MySQL数据库安装后通常默认的管理员用户名为
  • sqlserver2000数据库迁移到2008r2
  • 在Windows Server 2008服务器的三种角色
  • 自动保存怎么恢复
  • 桌面开始菜单跑到右边去了怎么办
  • ubuntu 命令行修改用户密码
  • mac系统怎么设置默认应用
  • javascript基于
  • css美化表单 案例
  • Node.js中的事件循环是什么样的
  • 查询同一网段下的其他ip
  • 批处理set命令
  • shell if -lt
  • python数据连接
  • Ubuntu 16.04 LTS中源码安装Python 3.6.0的方法教程
  • javascript教程完整版
  • easyui treegrid重新加载
  • 厦门市无纸化税务局官网
  • 金融机构取得的利息收入应缴纳增值税的
  • 广州财务顾问公司
  • 开展志愿服务关爱活动
  • 我国公益性企业有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设