IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react—Hook中useReducer详解(举个例子 ) -> 正文阅读

[JavaScript知识库]react—Hook中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本篇的文章就到这里啦,如果对你有帮助,点赞关注支持一下呀,后续会持续给大家带来优质内容~

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:40:43  更:2022-03-21 20:41:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:20:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码