react—Hook中useReducer详解(举个例子 )

简介: 在hooks中,可以为函数式组件提供类似Redux的功能,类似于vuex都是提供状态管理的。官方提供的两种state管理:useState,useReducer。下面我们一起来看看useReducer的用法

useReducer

在hooks中,可以为函数式组件提供类似Redux的功能,类似于vuex都是提供状态管理的。官方提供的两种state管理:useState,useReducer。下面我们一起来看看useReducer的用法

实现累加器

举个简单例子来了解它的使用方法,点击按钮实现累加:
1.首选前面要引入useReducer,后面要使用它
2.定义[state, dispatch]来接收我们后面的useReducer,因为useReducer包含两个参数,一个参数为useReducer的函数,一个为初始值
3.在按钮中绑定点击事件,触发useReducer的事件需要使用dispatch,另外我们这里在函数中进行判断,如果action为add就累加1,否则返回state

import React, { useReducer } from 'react'

export default function App() {
    const [state, dispatch] = useReducer((state, action) => {
        if(action === 'add') {
            return state+1
        }
        return state
    }, 0)
    return (
        <div>App
            <h1>{state}</h1>
            <button onClick={() => dispatch('add')}>+1</button>
        </div>
    )
}

这样就实现了效果:
在这里插入图片描述
上面代码中注意区分,useReducer中箭头函数后面的第一个值为操作状态的函数(累加的-判断),第二个值为0(初始值)

我们还可以使用case改写一下,加个功能:
原理都是一样的,使用这里的dispatch进行操作

export default function App() {
    const [state, dispatch] = useReducer((state, action) => {
        switch(action) {
            case 'add':
                return state+1
            case 'sub':
                return state-1
            default:
                return state
        }
    }, 0)
    return (
        <div>App
            <h1>{state}</h1>
            <button onClick={() => dispatch('add')}>+1</button>
            <button onClick={() => dispatch('sub')}>-1</button>
        </div>
    )
}

实现效果:
在这里插入图片描述

拆分改写

为了让大家看的更清楚用法,下面再给大家看一种写法,把上面的进行拆分,实现一样的功能:

const iniState = {count:0}

function reducer(state, action) {
    switch(action.type) {
        case 'add':
            return {count: state.count + 1}
        case 'sub':
            return {count: state.count - 1}
        default:
            throw new Error()
    }
}
export default function App() {
    const [state, dispatch] = useReducer(reducer,iniState)
    return (
        <div>App
            <h1>{state.count}</h1>
            <button onClick={() => dispatch({type: 'add'})}>+1</button>
            <button onClick={() => dispatch({type: 'sub'})}>-1</button>
        </div>
    )
}

这里就相当于把useReducer的两个参数单拿出来写,并且在dispatch中传什么值都是可以的,我这里传的是对象,把函数和初始值单拿出来写也是可行的,实现一样的效果

useReducer的使用场景

  1. 如果说你的state是一个数组或者是对象
  2. 如果你的state变化很复杂,经常一个操作需要修改很多的state
  3. 如果你的应用比较大,希望UI和业务能够分开维护的时候

OK本篇的文章就到这里啦,如果对你有帮助,点赞关注支持一下呀,后续会持续给大家带来优质内容~

相关文章
|
23小时前
|
前端开发 JavaScript
【边做边学】React Hooks (二)——useEffect Hook
【边做边学】React Hooks (二)——useEffect Hook
|
23小时前
|
前端开发 JavaScript
React中useEffect Hook使用纠错
React中useEffect Hook使用纠错
19 0
|
1天前
|
存储 前端开发 测试技术
useReducer 的奇妙世界:探索 React 状态管理的新境界(下)
useReducer 的奇妙世界:探索 React 状态管理的新境界(下)
|
1天前
|
前端开发
useReducer 的奇妙世界:探索 React 状态管理的新境界(中)
useReducer 的奇妙世界:探索 React 状态管理的新境界(中)
|
1天前
|
前端开发 开发者
useReducer 的奇妙世界:探索 React 状态管理的新境界(上)
useReducer 的奇妙世界:探索 React 状态管理的新境界(上)
useReducer 的奇妙世界:探索 React 状态管理的新境界(上)
|
1天前
|
自然语言处理 前端开发 JavaScript
说说你对 React Hook的闭包陷阱的理解,有哪些解决方案?
说说你对 React Hook的闭包陷阱的理解,有哪些解决方案?
52 0
|
5月前
|
自然语言处理 前端开发 JavaScript
美丽的公主和它的27个React 自定义 Hook(四)
美丽的公主和它的27个React 自定义 Hook(四)
|
5月前
|
存储 前端开发 数据可视化
美丽的公主和它的27个React 自定义 Hook(三)
美丽的公主和它的27个React 自定义 Hook(三)
|
5月前
|
存储 JSON 前端开发
美丽的公主和它的27个React 自定义 Hook(二)
美丽的公主和它的27个React 自定义 Hook(二)
|
5月前
|
前端开发 JavaScript API
美丽的公主和它的27个React 自定义 Hook(一)
美丽的公主和它的27个React 自定义 Hook(一)