react18【系列实用教程】useReducer —— 升级版的 useState (2024最新版)

简介: react18【系列实用教程】useReducer —— 升级版的 useState (2024最新版)

useReducer 可看做升级版的 useState ,其强大之处在于,可以自定义复杂的响应式变量修改逻辑。

useReducer 语法

useReducer 是 hook 函数

  • 第一个参数(必要): 自定义的 reducer 函数(详见下文介绍)
  • 第二个参数(必要): 响应式变量的初始值
  • 第三个参数(可选):自定义的 init 函数(详见下文介绍),实现惰性初始化
  • 返回:一个数组,第一项为响应式变量,第二项为 dispatch 方法(详见下文介绍)

范例 – 计数器

import { useReducer } from "react";

function init(initialCount) {
  return { count: initialCount };
}

function reducer(state, action) {
  switch (action.type) {
    case "increment":
      return { count: state.count + 1 };
    case "decrement":
      return { count: state.count - 1 };
    case "reset":
      return init(action.payload);
    default:
      throw new Error();
  }
}

function Counter({ initialCount }) {
  const [state, dispatch] = useReducer(reducer, initialCount, init);
  return (
    <>
      Count: {state.count}
      <button
        onClick={() => dispatch({ type: "reset", payload: initialCount })}
      >
        Reset
      </button>
      <button onClick={() => dispatch({ type: "decrement" })}>-</button>
      <button onClick={() => dispatch({ type: "increment" })}>+</button>
    </>
  );
}

export default Counter;

父组件

import Counter from "./test.jsx";

export default function Index() {
  return (
    <div>
      <Counter initialCount={0} />
    </div>
  );
}

范例解析

若用 useState 实现,代码如下:

function Counter({initialCount}) {
  const [count, setCount] = useState(initialCount);
  return (
    <>
      Count: {count}
      <button onClick={() => setCount(initialCount)}>Reset</button>
      <button onClick={() => setCount(prevCount => prevCount - 1)}>-</button>
      <button onClick={() => setCount(prevCount => prevCount + 1)}>+</button>
    </>
  );
}

对比可知:

  • useReducer 将响应式变量作为 state 对象的属性来处理
  • setCount 的参数为响应式变量的新值
  • dispatch 的参数为修改响应式变量的逻辑参数,统一在 reducer 中定义具体的处理逻辑

init 函数

用于对响应式变量进行惰性初始化,传入初始值参数,返回响应式变量的初始值。

function init(initialCount) {
  return { count: initialCount };
}

reducer 函数

描述复杂的响应式变量修改逻辑

  • 第1个参数为:响应式变量
  • 第2个参数为:dispatch 方法传入的参数(内含修改逻辑的关键信息)
  • 返回 state 的新值
function reducer(state, action) {
  switch (action.type) {
    case "increment":
      return { count: state.count + 1 };
    case "decrement":
      return { count: state.count - 1 };
    case "reset":
      return init(action.payload);
    default:
      throw new Error();
  }
}

dispatch 方法

用于触发响应式变量的改变

  • 参数为一个对象,内含修改响应式变量的逻辑参数
  • dispatch 方法的执行,实际上是执行 reducer 函数,实现 state 的更新,并触发视图更新。
目录
相关文章
|
5月前
|
前端开发 JavaScript
深入理解并实践React Hooks —— useEffect与useState
深入理解并实践React Hooks —— useEffect与useState
201 1
|
3月前
|
前端开发
深入探索React Hooks:从useState到useEffect
深入探索React Hooks:从useState到useEffect
39 3
|
3月前
|
前端开发 JavaScript
深入探索React Hooks:从useState到useEffect
深入探索React Hooks:从useState到useEffect
|
6月前
|
前端开发
react中 useContext 和useReducer的使用
react中 useContext 和useReducer的使用
react中 useContext 和useReducer的使用
|
4月前
|
前端开发 JavaScript CDN
React 教程
10月更文挑战第6天
68 3
|
3月前
|
前端开发 JavaScript 中间件
React中使用​​useReducer​​​高阶钩子来管理状态
通过本文的介绍,您可以在React中使用 `useReducer`高阶钩子来管理复杂的状态逻辑。`useReducer`不仅提供了清晰的状态管理方式,还可以通过与 `useContext`结合,实现全局状态管理。此外,通过自定义中间件,可以进一步扩展其功能。希望本文对您理解和应用 `useReducer`有所帮助。
53 0
|
5月前
|
Web App开发 前端开发 测试技术
react18基础教程系列--安装环境及packagejson文件分析
react18基础教程系列--安装环境及packagejson文件分析
|
4月前
|
存储 前端开发 JavaScript
React useState 和 useRef 的区别
本文介绍了 React 中 `useState` 和 `useRef` 这两个重要 Hook 的区别和使用场景。`useState` 用于管理状态并在状态变化时重新渲染组件,适用于表单输入、显示/隐藏组件、动态样式等场景。`useRef` 则用于在渲染之间保持可变值而不触发重新渲染,适用于访问 DOM 元素、存储定时器 ID 等场景。文章还提供了具体的代码示例,帮助读者更好地理解和应用这两个 Hook。
90 0
|
5月前
|
前端开发
React中函数式Hooks之useState的使用
本文介绍了React中函数式组件的Hooks——`useState`的使用方法。`useState`允许在函数式组件中使用状态,它返回一个数组,其中包含当前状态的值和更新该状态的函数。文章通过示例代码展示了如何声明状态变量和更新状态变量,包括对数值和对象状态的更新。此外,还展示了如何通过点击按钮触发状态更新,实现交互功能。
48 1
|
6月前
|
前端开发 开发者
介绍React的useState
【8月更文挑战第6天】 介绍React的useState
59 1