useMemo钩的作用是什么(附代码示例)

简介: useMemo 钩子是用来返回一个缓存的值,以节省任何重新计算的开销。它的工作原理与useCallback 钩子类似;你可以在这里阅读更多关于它的信息。

简介
useMemo 钩子是用来返回一个缓存的值,以节省任何重新计算的开销。它的工作原理与useCallback 钩子类似;你可以在这里阅读更多关于它的信息。
useMemo 钩子被用来阻止一个组件重新渲染,除非它的道具发生了变化,这意味着我们现在可以隔离资源密集型的计算值,这样它们就不会在每个组件渲染时自动运行。
最好是展示一个有利于使用该钩子的场景,这样我们就能更好地理解我们为达成一个问题所采取的步骤,然后再解释使用useMemo 钩子背后的思考过程。
项目概述
我们将从搭建一个全新的React项目的脚手架开始。首先,我们将创建一个新的项目目录,之后,我们将使用终端初始化一个新项目。
在这个过程中,你可以使用npm、npx或者yarn。你要运行的命令是:

npm。npm init react-app app-name
npx: npx create-react-app app-name
yarn。yarn create react-app app-name

现在我们已经设置好了一切,让我们直接进入有趣的部分。
项目进展
由于这是一个小项目,我们将把所有的代码放在根src 目录下的App.js 文件内,它看起来会是这样的:
import { useState } from "react";
import "./App.css";

const App = () => {
const [count, setCount] = useState(0);
const [todos, setTodos] = useState([]);

const calculation = expensiveCalculation(count);

const increment = () => {

setCount((c) => c + 1);

};

const addTodo = () => {

setTodos((t) => [...t, "New Todo"]);

};

return (

<div className="App">
  <div>
    <h2>My Todos</h2>
    {todos.map((todo, index) => {
      return <p key={index}>{todo}</p>;
    })}
    <button onClick={addTodo}>Add Todo</button>
  </div>
  <hr />
  <div>
    Count: {count}
    <button onClick={increment}>+</button>
    <h2>Expensive Calculation</h2>
    {calculation}
  </div>
</div>

);
};

const expensiveCalculation = (num) => {
console.log("Calculating...");

for (let i = 0; i < 1000000000; i++) {

num += 1;

}

return num;
};

export default App;
复制代码
上面的应用程序相当简单,我们有一个todos列表,一个计数器元素,最后是一个函数,一旦调用,就会触发一些昂贵的计算。
你可以注意到,每次组件重新显示时都会调用这个函数。
那么,问题出在哪里?
当添加一个新的todo时,你会注意到在发生任何事情之前会有一个轻微的延迟。这是不应该的,因为无论从视觉上还是功能上,它们都是不相关的。
添加todo的延迟
问题的根本原因
延迟是由每次重新渲染App 组件时触发的昂贵计算造成的。App 组件的重新渲染是由其状态的变化引起的。
解决方案
这是一个使用useMemo 钩子的完美场景,因为它被设想为帮助我们在处理昂贵的计算时提高性能,如函数调用。
通过将我们的expensiveCalculation 函数调用包裹在useMemo 钩子中,我们将确保这个函数调用的结果只有在钩子作为辅助参数的依赖数组的值发生变化时才会被重新计算,否则它将被缓存起来,不会受到外部状态变化或组件重新渲染的影响。
有了useMemo ,我们的expensiveCalculation 函数反而会被这样使用。
const calculation = useMemo(() => expensiveCalculation(count), [count]);
复制代码
通过将count 变量传递给useMemo's hook dependency array,我们让React知道,除非count 变量的值发生变化,否则我们要改变expensiveCalculation 函数调用的结果。
如果你现在尝试重新加载你的浏览器标签,并尝试添加一个新的todo,你将能够注意到它不再滞后了。
使用useMemo钩子后,缓存了昂贵的计算过程
这只会在更新count 状态变量的值时发生,这是预期的。

你可以在这里了解更多关于memo HoC的信息。其功能与useMemo 钩子类似,区别在于语法。你可以在这篇文章中查看一个实际的使用案例。

总结
我希望你喜欢阅读这篇文章,并希望你能更好地理解什么是useMemo 钩子,它的作用,以及你应该何时使用它。

相关文章
|
8月前
第34节: Vue3 调用内联处理程序中的方法
第34节: Vue3 调用内联处理程序中的方法
69 1
|
编译器 C++
50 C++ - 如何实现动态绑定
50 C++ - 如何实现动态绑定
59 0
50 C++ - 如何实现动态绑定
|
3月前
|
JavaScript 索引
如何避免在事件处理方法中使用箭头函数
在Vue组件中,应避免使用箭头函数定义事件处理方法,因其可能导致`this`绑定问题及额外的性能开销。推荐在`methods`选项中定义普通函数,确保`this`正确指向组件实例,同时可通过`bind`方法或直接在事件绑定中传递参数,以实现复杂的参数传递需求。
|
3月前
|
设计模式 JavaScript 开发工具
Vue开发中使用好钩子方法(hook method)可以使你的代码更加模块化和可维护
Vue开发中使用好钩子方法(hook method)可以使你的代码更加模块化和可维护
31 0
|
7月前
|
自然语言处理 JavaScript 前端开发
在JavaScript中,this关键字的行为可能会因函数的调用方式而异
【6月更文挑战第15天】JavaScript的`this`根据调用方式变化:非严格模式下直接调用时指向全局对象(浏览器为window),严格模式下为undefined。作为对象方法时,`this`指对象本身。用`new`调用构造函数时,`this`指新实例。`call`,`apply`,`bind`可显式设定`this`值。箭头函数和绑定方法有助于管理复杂场景中的`this`行为。
63 3
|
6月前
|
前端开发
react18【系列实用教程】Hooks 闭包陷阱 (2024最新版)含useState 闭包陷阱,useEffect 闭包陷阱,useCallback 闭包陷阱
react18【系列实用教程】Hooks 闭包陷阱 (2024最新版)含useState 闭包陷阱,useEffect 闭包陷阱,useCallback 闭包陷阱
82 0
|
7月前
|
测试技术 编译器 C#
一篇文章讲明白hook(钩子程序)(转载)
一篇文章讲明白hook(钩子程序)(转载)
302 0
|
8月前
|
存储 缓存 前端开发
我知道你想用useEffect,但你先别急
useEffect是React提供给我们的一个“逃生舱”,是React 的纯函数式世界通往命令式世界的“逃生通道”,选择合适的时机使用useEffect会让我们的代码既优雅又高效,反之会造成不必要的负担。
函数修饰器的理解
函数修饰器的理解
40 0
|
JavaScript 前端开发
js函数调用的方式有几种
js函数调用的方式有几种
62 0