我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ReactuseReducer终极使用教程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ReactuseReducer终极使用教程

1. 概述

useReducer 这个 Hooks 在使用上几乎跟 Redux 一模一样,唯一缺点的就是无法使用 redux 提供的中间件。

使用 hook 函数后,一般情况下,一个组件组中的数据我们可以用 useReducer 来管理,而不是用 redux 来完成,redux 一般存储公用数据,而不是把所有的数据都存储在里面,redux 它是一个单一数据源,如果存储多个数据的话,性能会降低。

2. useReducer使用

import React, { useReducer } from 'react'
// useReducer 它就是一个小型的redux,它几乎和redux是一样的,也可以管理数据
// 初始化数据
const initState = {
  count: 100
}
// reducer纯函数中的state无需在定义函数时指定初始值,initState 会赋值给 reducer
// const reducer = (state,action)=>{}
// type, payload 是从 action 中结构出来的
const reducer = (state, { type, payload }) => {
  if (type === 'add') {
    return { ...state, count: state.count + payload }
  }
  return state
}
const App = () => {
  // state 它就是初始化后数据的对象,状态
  // dispatch 它就是用来发送指令让reducer来修改state中的数据
  // reducer它就是一个纯函数,用来修改initState初始化后数据状态函数
  // initState 初始化数据
  const [state, dispatch] = useReducer(reducer, initState)
  const addCount = () => {
    // 数据以改变就会触发 useReducer 中的 reducer 函数
    dispatch({ type: 'add', payload: 2 })
  }
  return (
    <div>
      <h3>App组件 -- {state.count}</h3>
      <button onClick={addCount}>++++</button>
    </div>
  );
}
export default App;

useReducer 的惰性初始化:

import React, { useReducer } from 'react'
const initState = {
  count: 100
}
const reducer = (state, { type, payload }) => {
  if (type === 'add') {
    return { ...state, count: state.count + payload }
  }
  return state
}
const App = () => {
  // initState 初始化数据
  // 如果useReducer它有第3个参数,则第2个参数就没有意义,它以第3个参数优先,第3个参数,惰性初始化,提升性能
  // 第3参数它是一个回调函数且一定要返回一个对象数据,当然你也可以直接返回一个值也可以,不建议
  const [state, dispatch] = useReducer(reducer, null, () => ({ count: 2000 }))
  const addCount = () => {
    dispatch({ type: 'add', payload: 2 })
  }
  return (
    <div>
      <h3>App组件 -- {state.count}</h3>
      <button onClick={addCount}>++++</button>
    </div>
  );
}
export default App;

注意:惰性初始化可以提升性能,惰性初始化使得数据不会在一开始就进行初始化,而是在使用的时候再进行初始化。

3. 使用useReducer完成todolist列表功能

reducer.js:

// 导出初始化数据
export const initState = {
  // 任务列表数据源
  todos: []
}
// 导出用于操作当前todos任务列表的纯函数
export const reducer = (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) }
  return state
}

父组件(App.jsx):

import React from 'react';
import Todo from './Todo';
const App = () => {
  return (
    <div>
      <Todo />
    </div>
  );
}
export default App;

ToDo组件:

import React, { useReducer } from 'react'
import Form from './components/Form'
import List from './components/List'
// 导入 reducer 文件中的初始化数据和操作数据函数
import { initState, reducer } from './reducer'
const Todo = () => {
  const [{ todos }, dispatch] = useReducer(reducer, initState)
  return (
    <div>
      {}
      <Form dispatch={dispatch} />
      {}
      <List dispatch={dispatch} todos={todos} />
    </div>
  )
}
export default Todo

表单项组件:

import React from 'react'
// 表单项组件
const Form = ({ dispatch }) => {
  // 回车事件
  const onEnter = evt => {
    if (evt.keyCode === 13) {
      const title = evt.target.value.trim()
      // todo每项中的数据
      const todo = {
        id: Date.now(),
        title,
        done: false
      }
      dispatch({ type: 'add', payload: todo })
      evt.target.value = ''
    }
  }
  return (
    <div>
      <input onKeyUp={onEnter} />
    </div>
  )
}
export default Form

任务项组件:

import React from 'react'
// 任务项组件
const List = ({ todos, dispatch }) => {
  const del = id => {
    dispatch({ type: 'del', payload: id })
  }
  return (
    <div>
      <h3>任务项</h3>
      <hr />
      <ul>
        {todos.map(item => (
          <li key={item.id}>
            <span>{item.title}</span>
            <span onClick={() => del(item.id)}>删除</span>
          </li>
        ))}
      </ul>
    </div>
  )
}
export default List

到此这篇关于React useReducer终极使用教程的文章就介绍到这了,更多相关React useReducer内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ReactuseReducer终极使用教程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ReactuseReducer终极使用教程

useReducer是在reactV16.8推出的钩子函数,从用法层面来说是可以代替useState。相信前期使用过React的前端同学,大都会经历从class语法向hooks用法的转变,react的hooks编程给我们带来了丝滑的函数式编程体验
2022-11-13

windows下安装Python和pip终极图文教程

本文希望提供傻瓜式的教程,能够令读者成功安装Python和pip。第一步,我们先来安装Python,博主选择的版本是最新的3.4.2版本。windows下面的Python安装一般是通过软件安装包安装而不是命令行,所以我们首先要在Python
2022-06-04

ASP 错误处理的终极教程:一步一步教你成为专家

本文将提供一份 ASP 错误处理的综合指南,从理解错误类型到采用最佳实践,一步一步教你成为专家,掌握有效的错误处理技巧。
ASP 错误处理的终极教程:一步一步教你成为专家
2024-02-10

终极win8美化教程 让你的win8系统与众不同

终极Windows8美化教程,附详细图解,本教程可以分几大方面:找回Aero/开始菜单/小工具。打造属于你的win8! 步骤如下:一.找回开始菜单二.安装Win7 Aero主题三.开启毛玻璃特效预览桌面四.找回小工具(貌似有一定风险)No.
2022-06-04

Python asyncio 终极教程:为你的代码注入速度和效率

asyncio 是 Python 中一个强大的异步编程库,可以大幅提升代码速度和效率。本教程将深入解析 asyncio,并通过代码示例演示其强大功能。
Python asyncio 终极教程:为你的代码注入速度和效率
2024-03-03

windows超级终端使用图文详细教程

&nbpythonsp;  为了使各位网络管理人员便于对防火墙、路由器及交换机等网络设备进行现场维护与管理,下面对终端控制平台,即超级终端的使用进行简要的配置说明,请大家按照以下步骤进行操作。超级终端软件方法/步骤1.鼠标依次单击&ldqu
2023-05-29

免激活合法使用Vista1年的终极方法

Vista免费!合法!不用激活!至少使用一年!   多么激动人心的字眼!Vista之家(www.vista123.com)团队第一时间拿到了国外的牛人大作,简单之极,只需更改注册表和执行两个命令行程序!   步骤1: 运行一个尚未激活的Wi
2023-05-24

终极版Python学习教程:一篇文章讲清楚Python虚拟环境

我在之前写过一篇Python学习教程,说过新手往往没有注意环境隔离,导致Python项目包与包之间冲突。并且Python2与3代码执行有问题等等。鉴于此我决定今天的Python学习教程给大家聊聊关于Python环境隔离问题以及如何进行隔离。
2023-06-02

编程热搜

目录