使用 useCallback 在 useSWR 中缓存您的 fetcher

我在gitroom源代码中找到了一种使用usecallback在useswr中缓存fetcher的方法。

使用 useCallback 在 useSWR 中缓存您的 fetcher

上图来自platform-analytics/render.analytics.tsx。让我们尝试理解这段代码。

我们将探索如何结合使用 usecallback 钩子和 useswr 来优化 react 应用程序中的数据获取。我们将分解提供的代码片段,解释为什么缓存 fetcher 函数很重要。

理解代码

让我们一步步深入代码:

const load = usecallback(async () => {  setloading(true);  const load = (    await fetch(`/analytics/${integration.id}?date=${date}`)  ).json();  setloading(false);  return load;}, [integration, date]);

在这里,我们在 usecallback 挂钩内定义异步函数加载。该函数从指定端点获取数据并处理加载状态。 usecallback 挂钩确保此函数被记忆,并且仅在依赖项(集成和日期)更改时重新创建。

接下来,我们使用 useswr 来管理数据获取:

const { data } = useswr(`/analytics-${integration?.id}-${date}`, load, {  refreshinterval: 0,  refreshwhenhidden: false,  revalidateonfocus: false,  revalidateonreconnect: false,  revalidateifstale: false,  refreshwhenoffline: false,  revalidateonmount: true,});

这里,useswr 配置了一个键(/analytics-${integration?.id}-${date})和我们的记忆加载函数。配置选项控制数据的重新验证行为。

usecallback 如何防止不必要的重新获取

要了解 usecallback 如何防止不必要的重新获取,我们需要深入研究 react 如何处理函数引用以及 useswr 如何工作。

react 中的函数引用

在 react 中,每次组件重新渲染时,都会重新创建其中定义的所有函数。这意味着如果没有 usecallback,将在每次渲染时创建加载函数的新实例。

使用 useCallback 在 useSWR 中缓存您的 fetcher

对 useswr 的影响

useswr 是 react 的数据获取库。它使用密钥来识别数据,并使用获取器函数来获取数据。 useswr 依赖于 fetcher 函数引用的稳定性。如果引用发生变化,useswr 可能会将其解释为需要重新获取数据的信号,即使获取器的实际逻辑没有改变。

存了个图 存了个图

视频图片解析/字幕/剪辑,视频高清保存/图片源图提取

存了个图 17 查看详情 存了个图

详细解释如下:

没有 usecallback:

const load = async () => {  setloading(true);  const load = (    await fetch(`/analytics/${integration.id}?date=${date}`)  ).json();  setloading(false);  return load;};const { data } = useswr(`/analytics-${integration?.id}-${date}`, load, {  refreshinterval: 0,  refreshwhenhidden: false,  revalidateonfocus: false,  revalidateonreconnect: false,  revalidateifstale: false,  refreshwhenoffline: false,  revalidateonmount: true,});

在这种情况下,每个渲染都会创建一个新的加载函数。 useswr 每次都会看到不同的函数引用,即使集成和日期没有更改,这也可能导致不必要的重新获取。

with usecallback:

const load = useCallback(async () => {  setLoading(true);  const load = (    await fetch(`/analytics/${integration.id}?date=${date}`)  ).json();  setLoading(false);  return load;}, [integration, date]);const { data } = useSWR(`/analytics-${integration?.id}-${date}`, load, {  refreshInterval: 0,  refreshWhenHidden: false,  revalidateOnFocus: false,  revalidateOnReconnect: false,  revalidateIfStale: false,  refreshWhenOffline: false,  revalidateOnMount: true,});

通过将 load 函数包装在 usecallback 中,我们确保仅在其依赖项(集成和日期)发生变化时才重新创建它。函数引用的这种稳定性告诉 useswr,除非集成或日期发生变化,否则获取器函数不会改变,从而防止不必要的重新获取。

想学习如何从头开始构建 shadcn-ui/ui 吗?查看 从头开始构建

关于我:

网站:https://ramunarasinga.com/

linkedin:https://www.linkedin.com/in/ramu-narasinga-189361128/

github:https://github.com/ramu-narasinga

电子邮件:ramu.narasinga@gmail.com

从头开始构建 shadcn-ui/ui

参考:

https://github.com/gitroomhq/gitroom/blob/c03b96215fa30b267a97d7eafc2281f482a3192f/apps/frontend/src/components/platform-analytics/render.analytics.tsx#l25 https://github.com/search?q=repo%3agitroomhq%2fgitroom%20useswr&type=code https://swr.vercel.app/docs/getting-started https://react.dev/reference/react/usecallback

以上就是使用 useCallback 在 useSWR 中缓存您的 fetcher的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/467434.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 06:01:01
下一篇 2025年11月8日 06:02:08

相关推荐

  • 什么是C++中的安装程序?

    c++++中的安装程序不是语言本身的一部分,而是用于部署c++应用的工具。常见的类型包括:1.独立安装程序(如nsis),2.网络安装程序(如wix),3.包管理器(如vcpkg)。创建安装程序需经过准备文件、选择工具、编写脚本、测试和发布等步骤。 C++中的安装程序(Installer)并不是C+…

    2025年12月18日
    000
  • 如何实现C++中的跨平台构建?

    c++++中的跨平台构建可以通过使用cmake、autotools、meson等构建系统和sdl、boost等平台抽象库来实现。1. 使用cmake进行条件编译和链接,生成不同平台所需的构建文件。2. 利用sdl或boost简化代码,使其在不同操作系统上保持一致性。3. 进行广泛的测试和调试,确保代…

    2025年12月18日
    000
  • xcode 怎么创建 c++ 项目

    在 xc++ode 中创建 c++ 项目可以通过以下步骤实现:1. 打开 xcode,点击 “create a new xcode project”。2. 选择 “macos” 平台和 “command line tool” 模…

    2025年12月18日
    000
  • clion 怎么创建 c++ 项目

    在 c++lion 中创建 c++ 项目可以通过以下步骤实现:1. 启动 clion 并点击 “create new project”。2. 选择 “c++ executable” 作为项目类型。3. 设置项目位置,建议使用专门文件夹。4. 选择 c+…

    2025年12月18日
    000
  • Gulc:从头开始建造的C库

    本文开启了一个系列,介绍我正在开发的C99库:Gulc(Generic Utility Library的缩写)。该库主要用于学习和娱乐目的,旨在提供C标准库中安全内存管理和实用功能(如向量和无序映射),以简化C语言编程。未来将持续添加更多功能。 目前,该库包含一个简单的验证系统(类似于断言,但在发行…

    2025年12月18日
    000
  • vs 怎么管理多个 c++ 项目

    在 visual studio 中管理多个 c++++ 项目可以通过创建解决方案和使用 cmake 来实现。1. 创建新解决方案并添加 c++ 项目。2. 使用 cmake 管理项目依赖和配置。通过这些方法,可以高效地组织和维护多个 c++ 项目,提升开发效率。 引言 搞 C++ 开发的朋友们,管理…

    2025年12月18日
    000
  • Meson:使用无中造成的GIT项目作为依赖

    meson项目依赖处理:巧妙解决无meson.build文件的git项目依赖问题 许多优秀的Git项目缺乏Meson.build文件,这给使用Meson构建系统的开发者带来了挑战。本文将介绍一种方法,通过创建补丁文件来解决这个问题,并成功将一个没有Meson.build文件的Git项目作为子项目添加…

    2025年12月18日
    000
  • 网络服务安装

    推介会: 本 SAE(业务学习情况)项目旨在开发一个基于客户端-服务器架构的实时“CAT”网络讨论应用程序。该应用允许多个客户端连接到中央服务器并进行实时通信。下图概述了套接字功能: 资源配置: 编程语言:C 语言版本控制:使用分布式 Github 进行代码共享开发环境:Visual Studio …

    2025年12月18日
    000
  • CSS Grid 布局在 IE 中不兼容的原因及解决方案

    IE 不兼容 CSS Grid 布局的原因是它不支持 CSS Grid 规范。解决方案包括:1. 使用 polyfills 模拟现代浏览器功能;2. 切换到支持 CSS Grid 布局的浏览器;3. 使用替代布局技术(如 Flexbox)。 CSS Grid 布局在 IE 中不兼容的原因 CSS G…

    2025年12月18日
    000
  • 探索文件拆分和合并:管理大文件的革命性工具

    您是否曾在传输或存储大量文件时遇到困难?了解 File Splitter & Merger,这是一个开源项目,旨在以优雅和高效的方式简化这一挑战。 这个项目是做什么的? 文件分割和合并由两个工具组成: 文件分割器 — 将大文件分成更小的块。 文件合并 — 将这些块重新组合成原始文件 为什么有…

    2025年12月18日
    000
  • NFetch

    大家好。 我想与你分享我的新项目。最近我了解了 neofetch 项目归档,并决定尝试用 c 语言编写我的模拟。 现在基本功能已经实现,使用flags进行数据输出等 您可以在链接中找到该项目的源代码:https://github.com/nighty3098/nfetch 安装: git clone…

    2025年12月18日
    000
  • 获取下一行学习如何处理文件描述符和系统 I/O 的项目

    在 c 编程领域,有效管理输入、输出和内存是基础。为了帮助您掌握这些关键概念,您将在 get_next_line 项目中编写一个使用文件描述符逐行读取文件的函数。每次调用该函数都会从文件中读取下一行,从而允许您一次一行处理整个文件内容。 了解系统中的文件描述符和 i/o 什么是文件描述符? 文件描述…

    2025年12月18日
    000
  • 使用免费 NET DIO + Randstad 的后端训练营

    免费的 bootcamp coding the future randstad – backend with .net 对于任何想要专注于 c# 编程语言和 microsoft 开发生态系统的人来说都是一个绝佳的机会。 凭借超过 8,000 个奖学金,参与者将有机会学习 .net 基础知识,成为能够…

    2025年12月18日 好文分享
    000
  • 如何为 C++ 函数库函数贡献代码?

    为 c++++ 函数库贡献代码的指南:选择函数库并了解其贡献流程。创建 issue 描述你的问题或功能请求。编写代码更改并创建 pull request。撰写清晰的编码注释。遵循函数库的编码风格。编写测试用例以确保代码正常工作。 如何为 C++ 函数库函数贡献代码 简介 对开源 C++ 函数库进行贡…

    2025年12月18日
    000
  • C++ 函数的库函数的依赖性和版本管理如何处理?

    c++++ 函数的库函数依赖性管理包括静态链接或动态加载,版本管理涉及 abi 版本和源代码版本。通过检查版本号或使用符号链接可以确保兼容性。实战中,需安装库,检查 abi 版本,获取源代码版本,并使用适当的标志编译和链接程序。 C++ 函数的库函数依赖性和版本管理 在 C++ 中,函数通常会依赖于…

    2025年12月18日
    100
  • clion的安装与配置教程

    CLion是一款由JetBrains开发的C/C++ IDE。安装步骤包括:下载并安装CLion、安装CMake、选择工具链。配置步骤包括:导入项目、编译和运行、调试、代码格式化、添加插件。CLion支持多种功能,包括CMake构建、工具链选择、代码格式化、调试和插件扩展。 CLion 安装与配置教…

    2025年12月18日
    000
  • C++ 函数在人工智能中的广泛应用

    c++++ 函数在人工智能中被广泛应用,用于以下任务:分类:将数据分配到类别(如手写数字识别)回归:预测连续值(如预测房屋价格)聚类:将数据点分组到类似组中(如客户细分)特征工程、模型训练、推理和部署 C++ 函数在人工智能中的广泛应用 引言 C++ 是一门强大的编程语言,在人工智能 (AI) 领域…

    2025年12月18日
    000
  • 埃尔凡操作系统

    ErfanOS:全面控制之路 ErfanOS 是 ErfanKeyhani-1 (Me) 的一个定制操作系统项目,旨在摆脱对政府控制和企业运行系统的需求。它是一个完全 DIY 的操作系统,使用自定义程序集引导加载程序启动,在 32 位保护模式 下运行,并具有 基于 C 的内核。您可以在 QEMU 上…

    2025年12月18日
    000
  • clion和vscode哪个好

    哪款 IDE 更胜一筹?入门门槛:VSCode 门槛较低,适合初学者。语言支持:VSCode 支持多种语言,CLion 专注于 C/C++。调试功能:CLion 调试工具更全面。代码补全:两者均提供优秀补全,CLion 专注于 C/C++。版本控制:两者集成良好。价格:VSCode 免费,CLion…

    2025年12月18日
    000
  • C++ 函数性能优化与持续集成和持续交付的协同作用

    c++++ 函数性能优化与 ci/cd 协同作用概述:将函数性能优化集成到 ci/cd 管道,通过单元测试、基准测试和代码审查监测和改进性能。常见的优化实践包括算法和数据结构优化、内联函数、避免复制、内存访问优化和并发优化。实战案例:采用备忘录技术优化斐波那契函数,减少计算复杂度,并通过 ci/cd…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信