React基础之useReducer

useState适用于管理简单的状态逻辑,如单个状态值或少量不相关的值,useReducer适合管理复杂的状态逻辑

1.定义不懂的reducer函数,根据不同的action,返回不同的状态

2.组件中调用useReducer(reducer,0)=>[state,dispatch]

3.调用dispatch({type:'INC'}),同时reducer产生一个新的状态,使用这个新状态更新UI

import { useReducer } from "react";

function reduce(state,action){

switch(action.type){

case 'INC':

return state+1

case 'DEC':

return state-1

default:

return state

}

}

function App() {

const [state,dispatch] =useReducer(reduce,0)

return (

<div className="App">

this is app,{state}

<button onClick={()=>{dispatch({type:'INC'})}}>++</button>

<button onClick={()=>{dispatch({type:'DEC'})}}>--</button>

</div>

);

}

export default App;

如果我们需要action传参

只需要添加一个新的分支,并且使用payload指定参数即可

import { useReducer } from "react";

function reduce(state,action){

switch(action.type){

case 'SET':

return action.payload

default:

return state

}

}

function App() {

const [state,dispatch] =useReducer(reduce,0)

return (

<div className="App">

this is app,{state}

<button onClick={()=>{dispatch({type:'SET',payload:100})}}>更新</button>

</div>

);

}

export default App;

相关推荐
惊悚的毛毛虫2 分钟前
掘金免广告?不想看理财交流圈?不想看exp+8?
前端
springfe01018 分钟前
vue3组件 - 大文件上传
前端·vue.js
再学一点就睡16 分钟前
Vite 工作原理(简易版)—— 从代码看核心逻辑
前端·vite
NeilNiu26 分钟前
开源AI工具Midscene.js
javascript·人工智能·开源
好好好明天会更好32 分钟前
uniapp项目中小程序的生命周期
前端·vue.js
CF14年老兵1 小时前
「Vue 3 + View Transition 实现炫酷圆形缩放换肤动画」
前端·css·trae
Warren981 小时前
软件测试-Selenium学习笔记
java·javascript·笔记·学习·selenium·测试工具·安全
404_Not_Found111 小时前
用 react + ts 实现我的第一个 todoList
react.js
小璞1 小时前
05_CursorRules_代码审查篇_Rule_code-review
前端