React-hooks:useMemo

2024-05-13 12:20

本文主要是介绍React-hooks:useMemo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

useMemo 是一个 React Hook,它在每次重新渲染的时候能够缓存计算的结果。

const cachedValue = useMemo(calculateValue, dependencies)
参数
  • calculateValue:要缓存计算值的函数。它应该是一个没有任何参数的纯函数,并且可以返回任意类型。React 将会在首次渲染时调用该函数;在之后的渲染中,如果 dependencies 没有发生变化,React 将直接返回相同值。否则,将会再次调用 calculateValue 并返回最新结果,然后缓存该结果以便下次重复使用。

  • dependencies:所有在 calculateValue 函数中使用的响应式变量组成的数组。响应式变量包括 props、state 和所有你直接在组件中定义的变量和函数。如果你在代码检查工具中 配置了 React,它将会确保每一个响应式数据都被正确地定义为依赖项。依赖项数组的长度必须是固定的并且必须写成 [dep1, dep2, dep3] 这种形式。React 使用 Object.is 将每个依赖项与其之前的值进行比较。

返回值

在初次渲染时,useMemo 返回不带参数调用 calculateValue 的结果。

在接下来的渲染中,如果依赖项没有发生改变,它将返回上次缓存的值;否则将再次调用 calculateValue,并返回最新结果。

一、看一个实例

1. 实例诉求

在这里插入图片描述
如上图:

  1. 父组件下有【count1】、【count2】两个变量;
  2. 页面上有两个按钮,每次点击按钮分别控制两个变量+1;
  3. 最下边的 斐波那契数列根据【count1】的值来计算得出;
2.代码
import { useState } from "react";// 斐波那契数列
function fib(n) {console.log('重新调用fib计算函数');if (n < 3) {return 1;}return fib(n - 2) + fib(n - 1);
}function App() {const [count1, setCount1] = useState(0);const [count2, setCount2] = useState(0);const result = fib(count1);console.log('重新渲染组件');return (<><div>父组件:<button onClick={() => setCount1(count1 + 1)}>change count1: {count1}</button><button onClick={() => setCount2(count2 + 1)}>change count2: {count2}</button></div>斐波那契数列第【{count1}】个值为: {result}</>)
}export default App;
3.效果

在这里插入图片描述
在这里插入图片描述

4. 发现问题

对照【3】中的两张截图,我们发现即使 fib函数并不依赖 count2 变量,当count2变量变更时,仍会触发 fib函数,这是非常不合理且不应该的,需要处理。

二、解决问题

1. 明确诉求

诉求:· fib函数只依赖 count1 变量,只有当count1变量变更时,才需触发 fib函数,而count2变量变更时,不需要触发 fib函数·

2. 代码实现
...// 2. 使用 useMemoconst result = useMemo(() => {return fib(count1);}, [count1])
...
3. 效果

在这里插入图片描述

三、完整代码

import { useMemo, useState } from "react";// 斐波那契数列
function fib(n) {console.log('重新调用fib计算函数');if (n < 3) {return 1;}return fib(n - 2) + fib(n - 1);
}function App() {const [count1, setCount1] = useState(0);const [count2, setCount2] = useState(0);// 1. 未使用 useMemo// const result = fib(count1);// 2. 使用 useMemoconst result = useMemo(() => {return fib(count1);}, [count1])console.log('重新渲染组件');return (<><div>父组件:<button onClick={() => setCount1(count1 + 1)}>change count1: {count1}</button><button onClick={() => setCount2(count2 + 1)}>change count2: {count2}</button></div>斐波那契数列第【{count1}】个值为: {result}</>)
}export default App;

这篇关于React-hooks:useMemo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/985694

相关文章

React(五)UseEffect、UseRef

(一)useEffect useEffect – React 中文文档  useEffect hook用于模拟以前的class组件的生命周期,但比原本的生命周期有着更强大的功能 1.类组件的生命周期 在类组件编程时,网络请求,订阅等操作都是在生命周期中完成 import React, { Component } from 'react'export default class App e

QT 使用信号和槽,让QLabel的内容实时与QLineEdit同步,类似vue框架的双向绑定

在窗口里放置一个单行文本编辑器(QLineEdit)和一个标签控件(QLabel),实现的效果就是当编辑器的内容被编辑时,标 签控件同步显 示编辑控件里的内容 1)当 lineEdit 控件被用户编辑时,它会发出信号  2)希望标签控件自动同步修改文本,QLabel标签控件自带槽函数:   之前我们一直拿这个槽函数当普通成员函数来修改标签控件文本的,它本质是一个槽函数。接收端的槽函

关于html的line height问题以及编码

在改网页时候,发现line height撑不开高度,导致内容无法居中,但是别的页面却可以,而且经过反反复复的核对,发现样式和正确显示的样式基本没有任何出入,几经研究,最后终于发现 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transi

centos刚部署好就遇到Jquery file upload. Failed to resize image (original thumbnail)

英文网站老外给的回答是没有引入扩展库 extension=php_gd2.dll 报这个错误是因为 imagecreatetruecolor 他就是第三方插件要用到的php函数,没有他就搞点事情,让你好看,吼吼吼。 结果我就去php.ini文件找啊找啊找,就是没有找到结果在别人的一篇博文中找到了答案,没有下载扩展库,嗨!谁要我是Linux菜鸟 遇到的都是问题,bug,希望

【前端每日基础】day35——HTML5离线存储

HTML5引入了一些新的特性和API来增强Web应用的功能,其中之一就是离线存储。离线存储允许Web应用在没有网络连接的情况下仍能正常运行。以下是HTML5离线存储的主要技术和详细介绍: Web Storage (LocalStorage 和 SessionStorage) LocalStorage 概述:LocalStorage用于持久化存储数据,数据不会随页面会话结束而消失,除非明确删除。

Llama(二):Open WebUI作为前端界面,使用本机的llama3

目录 背景 Open WebUI是什么 工程能力特性 产品功能特性 用户体验特性 Open WebUI安装并使用 背景 Mac M1芯片,16G 内存 llama3 8B的部署参考Llama(一):Mac M1芯片运行Llama3-CSDN博客在Mac M1 16G内存环境中,部署并使用Llama3 8Bhttps://blog.csdn.net/hugo_lei/art

react ant design Upload 多文件上传 beforeUpload 会调用很多次,怎么只获取一次

当使用Ant Design的Upload组件实现多文件上传时,beforeUploadHandler函数会被每个选中的文件调用一次。如果您只想获取一次选中的文件而不是每个文件都触发一次处理逻辑,可以采取以下方法: 使用 useRef 钩子保存文件列表:可以使用React的useRef钩子在组件中保存一个文件列表变量,而不是使用useState。这样就可以确保文件列表只在初始选择文件时获取一次。示

SSMP整合案例第六步 在前端页面上利用axios和element-ui与后端交互实现增删改

新增操作 正常我们都是从新增功能书写 查看源码 显示的是这个 在vue里面开下来 这样就能显示 点击确定 就能把数据发送到后台进行保存 //弹出添加窗口handleCreate() {this.dialogFormVisible = true;},//重置表单resetForm() {},//添加handleAdd() {//绑定的是确定按钮 发起请求ax

《Java开发及前端最全面试题-Offer直通车》目录

Java开发是需求最广,工资高的细分领域,同时也是会的人最多,有的公司招1个Java开发,要面试几十甚至上百面试者,同时要求很高,要求通晓技术栈很多及很深深度。 如果你正准备面试,想要脱颖而出,那么《Java开发及前端最全面试题-Offer直通车》是你的不二选择。 本书汇集了多篇超过1万字的精华内容,无论是Java基础、数据库、SpringBoot和SpringCloud等必问的,还是前端、k

vue3加axios配合element-plus实现图片等文件本地上传,并获取服务器返回的真实地址数据,前端写法

小白写法嘿嘿 开发工具和关键词 开发工具: vscode 关键词:vue3、element-plus、axios 后端 后端业务逻辑处理使用的是unicloud的云函数,大家可以看我上一篇文章。 思路 1、禁止element-plus的el-upload组件自动上传,变成手动上传,提交表单时候统一处理上传文件 2、此时el-upload组件中的file文件保存到了