




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第ReactuseReducer终极使用教程目录1.概述2.useReducer使用3.使用useReducer完成todolist列表功能
1.概述
useReducer这个Hooks在使用上几乎跟Redux一模一样,唯一缺点的就是无法使用redux提供的中间件。
使用hook函数后,一般情况下,一个组件组中的数据我们可以用useReducer来管理,而不是用redux来完成,redux一般存储公用数据,而不是把所有的数据都存储在里面,redux它是一个单一数据源,如果存储多个数据的话,性能会降低。
2.useReducer使用
importReact,{useReducer}from'react'
//useReducer它就是一个小型的redux,它几乎和redux是一样的,也可以管理数据
//初始化数据
constinitState={
count:100
//reducer纯函数中的state无需在定义函数时指定初始值,initState会赋值给reducer
//constreducer=(state,action)={}
//type,payload是从action中结构出来的
constreducer=(state,{type,payload})={
if(type==='add'){
return{...state,count:state.count+payload}
returnstate
constApp=()={
//state它就是初始化后数据的对象,状态
//dispatch它就是用来发送指令让reducer来修改state中的数据
//reducer它就是一个纯函数,用来修改initState初始化后数据状态函数
//initState初始化数据
const[state,dispatch]=useReducer(reducer,initState)
constaddCount=()={
//数据以改变就会触发useReducer中的reducer函数
dispatch({type:'add',payload:2})
return(
div
h3App组件--{state.count}/h3
buttonaddCount}++++/button
/div
exportdefaultApp;
useReducer的惰性初始化:
importReact,{useReducer}from'react'
constinitState={
count:100
constreducer=(state,{type,payload})={
if(type==='add'){
return{...state,count:state.count+payload}
returnstate
constApp=()={
//initState初始化数据
//如果useReducer它有第3个参数,则第2个参数就没有意义,它以第3个参数优先,第3个参数,惰性初始化,提升性能
//第3参数它是一个回调函数且一定要返回一个对象数据,当然你也可以直接返回一个值也可以,不建议
const[state,dispatch]=useReducer(reducer,null,()=({count:2000}))
constaddCount=()={
dispatch({type:'add',payload:2})
return(
div
h3App组件--{state.count}/h3
buttonaddCount}++++/button
/div
exportdefaultApp;
注意:惰性初始化可以提升性能,惰性初始化使得数据不会在一开始就进行初始化,而是在使用的时候再进行初始化。
3.使用useReducer完成todolist列表功能
reducer.js:
//导出初始化数据
exportconstinitState={
//任务列表数据源
todos:[]
//导出用于操作当前todos任务列表的纯函数
exportconstreducer=(state,{type,payload})={
//[...state.todos,payload]追加数据
if('add'===type)return{...state,todos:[...state.todos,payload]}
if('del'===type)return{...state,todos:state.todos.filter(item=item.id!=payload)}
returnstate
}
父组件(App.jsx):
importReactfrom'react';
importTodofrom'./Todo';
constApp=()={
return(
div
Todo/
/div
exportdefaultApp;
ToDo组件:
importReact,{useReducer}from'react'
importFormfrom'./components/Form'
importListfrom'./components/List'
//导入reducer文件中的初始化数据和操作数据函数
import{initState,reducer}from'./reducer'
constTodo=()={
const[{todos},dispatch]=useReducer(reducer,initState)
return(
div
{/*表单项*/}
Formdispatch={dispatch}/
{/*任务项*/}
Listdispatch={dispatch}todos={todos}/
/div
exportdefaultTodo
表单项组件:
importReactfrom'react'
//表单项组件
constForm=({dispatch})={
//回车事件
constonEnter=evt={
if(evt.keyCode===13){
consttitle=evt.target.value.trim()
//todo每项中的数据
consttodo={
id:Date.now(),
title,
done:false
dispatch({type:'add',payload:todo})
evt.target.value=''
return(
div
inputonKeyUp={onEnter}/
/div
exportdefaultForm
任务项组件:
importReactfrom'react'
//任务项组件
constList=({todos,dispatch})={
constdel=id={
dispatch({type:'del',payload:id})
return(
d
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 河南推拿职业学院《广播广告创作与欣赏》2023-2024学年第二学期期末试卷
- 湖南应用技术学院《生物药物分离纯化技术》2023-2024学年第二学期期末试卷
- 桂林信息工程职业学院《资源与环境领域前沿进展》2023-2024学年第二学期期末试卷
- 长治学院《计算机与互联网》2023-2024学年第二学期期末试卷
- 广西城市职业大学《教师资格证面试强化》2023-2024学年第二学期期末试卷
- 湖南冶金职业技术学院《测绘管理与法规》2023-2024学年第二学期期末试卷
- 广东科技学院《食品生物技术基础》2023-2024学年第二学期期末试卷
- 泉州海洋职业学院《中国民族民间舞蹈素材(一)》2023-2024学年第二学期期末试卷
- 上海出版印刷高等专科学校《化工设计与模拟》2023-2024学年第二学期期末试卷
- 河南农业大学《胶黏剂的发展与应用》2023-2024学年第二学期期末试卷
- 牛场安全培训
- 脑电图及临床应用
- 2025年重庆中考语文a试题及答案2024
- 大学生的人际交往困境与突破
- 第八单元常见的酸、碱、盐基础练习题-+2024-2025学年九年级化学科粤版(2024)下册
- 2024国家安全教育大学生读本题库
- 黄河文化(齐鲁工业大学)知到智慧树章节测试课后答案2024年秋齐鲁工业大学
- 变电站电网侧储能项目可行性研究报告
- 第十二周《遇见劳动之美点亮成长底色》主题班会
- 世界环境日环保教育班会 课件
- 临床诊疗指南-疼痛学分册
评论
0/150
提交评论