React学习笔记16

一、useReducer

作用:和useState的作用类似,用来管理相对复杂的状态数据

使用:

1、定义一个reducer函数(根据不同的action返回不同的新状态)

2、在组件中调用useReducer,并传入reducer函数的状态和初始值

import { useReducer } from "react"

function reducer(state, action) {
    switch (action.type) {
        case 'add':
            return state += 1
        case 'DEC':
            return state -= 1;
        default:
            return state
    }
}

const Login = () => {
    const [state, dispatch] = useReducer(reducer, 0)
    return (
        <>
            <div>{state}</div>
            <button onClick={()=>dispatch({type:'add'})}>+</button>
        </>

    )
}

export default Login

如何更新state?在dispatch中多加一个载荷payload(规范)

import { useReducer } from "react"

function reducer(state, action) {
    switch (action.type) {
        case 'add':
            return state += 1
        case 'DEC':
            return state -= 1;
        case 'update':
            return action.payload;
        default:
            return state
    }
}

const Login = () => {
    const [state, dispatch] = useReducer(reducer, 0)
    return (
        <>
            <div>{state}</div>
            <button onClick={()=>dispatch({type:'add'})}>+</button>
            <button onClick={()=>dispatch({type:'update',payload:100})}>update</button>
        </>

    )
}

export default Login

 

下一章:useMemo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值