了解 React Cache 功能

news/2024/9/21 16:54:31/文章来源:https://www.cnblogs.com/aow054/p/18424209
随着react生态系统的不断扩大,优化数据获取的更强大的工具之一就是缓存功能。此内置功能允许您执行许多操作,例如有效管理和存储服务器数据、减少冗余网络请求以及提高整体应用程序性能。 在本文中,我们将了解 react 中的缓存功能、它的好处以及如何使用它。 什么是react缓存功能react 发布的缓存功能是为了优化性能而设计的。它是通过在将相同的参数传递给函数时避免不必要的计算来实现的。这可以通过一种称为记忆的机制来实现,即存储函数调用的结果,并在相同的输入再次发生时重新使用。 react 的缓存功能有助于防止函数使用相同的参数重复执行,从而节省计算资源并提高应用程序的整体效率。要使用缓存函数,您需要用缓存包装目标函数,react 负责存储函数调用的结果。当使用相同的参数再次调用包装的函数时,react 首先检查缓存。如果这些参数的结果存在于缓存中,它将返回缓存的结果,而不是再次执行该函数。 此行为确保函数仅在必要时运行,即当参数与之前看到的参数不同时。这是一个简单的示例,演示如何使用 react 的缓存功能在从天气应用程序获取数据时跳过重复的工作:import { cache } from 'react';import { Suspense } from 'react';const fetchWeatherData = async (city) =&gt; { console.log(`Fetching weather data for ${city}...`); // Simulate API call await new Promise(resolve =&gt; setTimeout(resolve, 2000)); return { temperature: Math.round(Math.random() * 30), conditions: ['Sunny', 'Cloudy', 'Rainy'][Math.floor(Math.random() * 3)] };};const getCachedWeatherData = cache(fetchWeatherData);async function WeatherWidget({ city }) { const weatherData = await getCachedWeatherData(city); return ( <div> <h2>Weather in {city}</h2> <p>Temperature: {weatherData.temperature}°C</p> <p>Conditions: {weatherData.conditions}</p> </div> );}function WeatherDashboard() { return ( <div> <suspense fallback="{&lt;div">Loading New York weather...</suspense></div>}&gt; <weatherwidget city="New York"></weatherwidget><suspense fallback="{&lt;div">Loading London weather...}&gt; <weatherwidget city="London"></weatherwidget></suspense><suspense fallback="{&lt;div">Loading New York weather...}&gt; <weatherwidget city="New York"></weatherwidget> {/* Duplicate */} </suspense><suspense fallback="{&lt;div">Loading Tokyo weather...}&gt; <weatherwidget city="Tokyo"></weatherwidget></suspense> );}export default WeatherDashboard;登录后复制在上面的代码中,缓存函数应用于 fetchweatherdata,创建了一个新函数 getcachedweatherdata 来存储天气数据获取的结果。然后,在 weatherwidget 组件中使用此缓存函数来检索不同城市的天气信息。 weatherdashboard 组件呈现 weatherwidget 的多个实例,其中包括纽约的重复实例,这是故意的。这是缓存机制的关键概念证明,因为它可以通过重用第一次调用的缓存结果来防止在渲染周期内多次请求相同数据时出现冗余且昂贵的操作,从而避免不必要的网络请求。这种缓存机制有几个优点:它减少了 api 调用的次数,从而提高了性能并降低了服务器负载;它确保请求相同信息的组件之间的数据一致性;它通过自动处理潜在的重复请求来简化组件代码。需要注意的是,react 的缓存功能仅适用于服务器组件。每次对缓存的调用都会创建一个新的记忆函数,这意味着使用同一函数多次调用缓存将导致产生不共享相同缓存的单独记忆版本。 还有一点需要注意的是,缓存函数会缓存成功的结果和错误的结果。因此,如果函数对某些参数抛出错误,该错误将被缓存,并在使用相同参数的后续调用时重新抛出。此功能是 react 提高性能和效率的更广泛策略的一部分,补充了虚拟 dom 以及 usememo 和 usecallback 挂钩等现有机制,这些机制还采用记忆技术来优化组件渲染和函数引用。 缓存功能的好处使用 react 缓存功能的好处主要围绕性能优化,特别是减少不必要的计算和数据获取操作。以下是缓存功能的一些主要优点:提高应用程序性能:缓存有助于通过跨多个组件重用缓存数据来减少所需的服务器请求数量。这会带来更快的响应时间和更流畅的用户体验,因为应用程序等待获取或计算数据的时间更少。高效数据获取:在涉及数据获取的场景中,尤其是在服务器端渲染或静态生成上下文中,缓存可以显着减少需要从服务器获取的数据量。这对于频繁请求相同数据或数据获取在性能方面成本较高的应用程序特别有用。减少服务器负载:通过从缓存提供数据而不是向服务器发出新请求,缓存有助于更均匀地分配负载。这可以提高后端服务的可扩展性和可靠性,因为它们不会被频繁的相同请求淹没。增强的用户体验:更快的加载时间和减少的延迟有助于提供更好的用户体验。用户可以更快地与应用程序交互,因为应用程序花费更少的时间来获取或计算数据。对高级缓存策略的支持:react 的缓存功能补充了其他缓存机制和策略,例如记忆化(usememo)和回调记忆化(usecallback)。这些工具共同提供了优化 react 应用程序的综合方法,使开发人员能够根据特定需求微调性能。 何时使用缓存功能您可以在需要时使用缓存功能:memoize 昂贵的数据获取:如果您的服务器组件依赖于从 api 获取数据或执行复杂的计算,则使用缓存包装数据获取功能可以显着提高性能。对于相同的参数,该函数只会执行一次,后续渲染将使用缓存的结果。预加载数据:您可以利用缓存在组件渲染之前预加载数据。这对于需要在初始渲染时立即可用的关键数据特别有用。跨组件共享结果:当多个服务器组件需要从服务器获取相同的数据时,使用缓存可确保发出单个请求,并且结果在所有组件之间共享,从而减少冗余服务器调用。 结论next.js 中的缓存功能与 react 的内置缓存功能相结合,提供了一个强大的工具包,用于优化应用程序中的数据获取和组件渲染。通过策略性地缓存数据和计算,您可以显着提高性能,减少不必要的 api 调用,并增强用户体验。请记住,react 的缓存功能是一项实验性功能,可能会发生变化。请始终参阅最新的 react 文档以获取最新信息和使用指南。 以上就是了解 React Cache 功能的详细内容,更多请关注我的其它相关文章!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/801083.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Zlmedia搭建简记

进入新公司之后,发现他们的视频播放使用的是ZlmediaKit这个工具,自己尝试使用了一下发现很好用,于是在自己机器上搭建了一个服务玩玩。 因为没有在线的摄像头,所以这里采用的是ffmpeg推送mp4文件作为视频流输入,推送到zlmedia服务,再利用zlmedia本身所带的拉流服务,最终…

C 风格字符串函数

▲《C++ Primer》 P109 我们无法保证 c_str 函数返回的数组一直有效,事实上,如果后续的操作改变了 string 的值就可能让之前返回的数组失去效用。 WARNING: 如果执行完 c_str() 函数后程序想一直都能使用其返回的数组,最好将该数组重新拷贝一份。

基于IDF的ESP32S3-LVGL DEMO移植

简介 ESP32-32出色的性价比,较好的性能与内存空间,可以好利用来完成GUI显示库的加载 LVGL LVGL是一款比较流行的致力于MCU与MPU创建漂亮UI的嵌入式图形库,免费且开源。 硬件 硬件采用的是正点原子的ESP32-S3 屏幕使用的是SPI通信方式,配合IO口控制(RST,A0),来实现LCD屏幕…

nginx: 按ip地址限流

一,以固定的速度提供服务 语法: 例子 limit_req_zone $binary_remote_addr zone=test:10m rate=2r/s;server { location / { limit_req zone=test; }} 语法: imit_req_zone 用于设置限流和共享内存区域的参数,格式为: limit_req_zone key zone rate。 key: 定…

Free5GC源码研究(2) - 单个NF的软件架构

前文我们总览了free5gc的总体软件架构。整一个free5gc系统又由几个NF(Network Function)组成,所以本文继续深入研究单个NF的软件架构。要研究NF的软件架构,最直接的方式是找一个简单的NF来回观摩。free5gc/ausf算是比较简单的一个,然而我发现了一个更简单的NF,叫做andy89…

一,初始 MyBatis-Plus

一,初始 MyBatis-Plus @目录一,初始 MyBatis-Plus1. MyBatis-Plus 的概述2. 入门配置第一个 MyBatis-Plus 案例3. 补充说明:3.1 通用 Mapper 接口介绍3.1.1 Mapper 接口的 “增删改查”3.1.1.1 查询所有记录3.1.1.2 插入一条数据3.1.1.3 删除一条数据3.1.1.4 更新一条数据3.…

[神经网络与深度学习笔记]LDA降维

LDA降维 LinearDiscriminant Analysis 线性判别分析,是一种有监督的线性降维算法。与PCA保持数据信息不同,LDA的目标是将原始数据投影到低维空间,尽量使同一类的数据聚集,不同类的数据尽可能分散 步骤:计算类内散度矩阵\(S_b\) 计算类间散度矩阵\(S_w\) 计算矩阵\(S_w^{-1…

C++ 指针和迭代器支持的操作

▲ 《C++ Primer》 P96 指针也都支持上面的操作。

代码整洁之道--读书笔记(14)

代码整洁之道简介: 本书是编程大师“Bob 大叔”40余年编程生涯的心得体会的总结,讲解要成为真正专业的程序员需要具备什么样的态度,需要遵循什么样的原则,需要采取什么样的行动。作者以自己以及身边的同事走过的弯路、犯过的错误为例,意在为后来者引路,助其职业生涯迈上更…

hexo安装后报错hexo 不是内部或外部命令,也不是可运行的程序 或批处理文件。

hexo问题 之前利用hexo和gitee搭建了一个博客,但是最近gitee的gitpage停止服务了,便想着在github上搭建一个。 在到安装hexo这一步的时候,一直报错hexo 不是内部或外部命令,也不是可运行的程序 或批处理文件。 我的所有安装步骤和环境变量发现都没有错,反复配置后去找了一…

跑冒滴漏监测系统

跑冒滴漏监测系统应用计算机视觉和深度学习技术对危化品生产区域实时检测,当检测到液体泄露时,立即抓拍存档告警并回传给后台监控平台方便人员及时处理,提高图像数据的实时监控效率。跑冒滴漏监测系统7*24小时不间断对监控画面实时分析监测,避免意外事故发生,同时降低人力…

学校食堂明厨亮灶监控系统

学校食堂明厨亮灶监控系统通过卷积神经网络学习与图像识别技术,学校食堂明厨亮灶监控系统将对现场监控画面进行24小时实时分析,如:厨房出现老鼠狗猫、厨师未戴口罩、厨师未戴厨师帽、厨师服穿戴识别、抽烟识别、玩手机识别,同时实时抓拍相关情况,全程记录留痕,提升监管效…