0

0

从 useEffect 到 React Query:在 React 中实现数据管理现代化

聖光之護

聖光之護

发布时间:2024-11-19 08:50:43

|

1118人浏览过

|

来源于dev.to

转载

从 useeffect 到 react query:在 react 中实现数据管理现代化

在现代 web 开发环境中,构建快速响应的应用程序来有效管理服务器端数据比以往任何时候都更加重要。在 react 中获取数据的传统方法,尤其是使用 useeffect,通常会导致复杂的状态管理、重复的代码和性能问题。借助 react query,开发人员可以利用自动缓存、后台获取和内置突变支持等功能,同时最大限度地减少样板代码。

在本文中,我们将探讨 react query 的核心概念,演示如何将其集成到我们的项目中,并重点介绍其可以显着改进您的开发工作流程的强大功能。准备好改变您在 react 应用程序中获取、缓存和同步数据的方式!

为什么我们应该停止使用 react effects 获取数据

虽然使用 react 的 useeffect 来获取数据是完全有效的,但有几个原因可以考虑放弃它,转而使用像 react query 这样的专用数据获取库(甚至 react 文档也建议使用 react query 来获取数据)。

使用 effects 获取数据的一些缺点:

  • 性能问题:“网络瀑布”和不必要的重新获取是使用 react useeffect 时的一些常见问题,可能会导致非常糟糕的用户体验。
  • 缺乏内置缓存:useeffect不提供开箱即用的缓存,这会导致重复的网络请求和复杂的管理解决方案。
  • 状态管理的复杂性:使用 useeffect 手动管理加载、错误和数据状态可能会导致代码繁琐且容易出错,尤其是在应用程序扩展时。
  • 效果不在服务器上运行:组件初始渲染时数据可能不可用。

react 查询如何工作

react query 是一个功能强大的库,旨在简化 react 应用程序中的数据获取和状态管理。以下是 react query 工作原理的详细说明:

1. 查询数据

  • usequery hook:react query 的核心是 usequery hook。这个钩子允许您从服务器获取数据并自动管理其状态(加载、错误、数据......)。
  • 查询键:每个查询都由唯一的键(数组中的一个或多个字符串)标识。这个键有助于 react query 缓存并有效地管理数据。

2. 缓存

  • 自动缓存:获取数据时,react query 会缓存它。如果再次进行相同的查询,它将从缓存中检索数据,而不是发出新的网络请求。
  • 过时数据管理:您可以定义数据应被视为新鲜(而不是过时)的时间。过了这段时间,react query 将在后台重新获取数据。

3. 后台重新获取

react query 在多种场景下自动重新获取数据,以保持数据新鲜和同步。发生这种情况的主要情况如下:

  • 组件的挂载:组件挂载时,如果数据被认为是陈旧的。
  • 窗口焦点:每当窗口重新获得焦点时,例如当用户在选项卡或窗口之间切换并返回到包含您的应用程序的窗口时。
  • 网络重连:如果网络连接丢失并稍后恢复。

4. 数据突变

  • usemutation hook:指在服务器上创建、更新或删除数据的过程。与检索数据的查询不同,usemutation 用于修改数据并管理与其相关的副作用。
  • 乐观更新:当用户执行会改变数据的操作时,ui 会立即更新以反映该操作的预期结果,从而增强用户体验。

5. 查询失效

  • react query 允许您将缓存的查询标记为“过时”,以便下次访问时重新获取它。这对于确保 ui 在执行某些操作(例如突变或用户交互)后反映来自服务器的最新数据至关重要。

6.自动垃圾收集

  • 当查询不再使用并且在一段时间内不活动时,react query 会自动从缓存中删除查询。此过程有助于防止内存泄漏并确保只有相关数据保留在缓存中。

7. 开发工具

  • react query devtools 是一个可选的、用户友好的 react query 工具,可以帮助我们开发人员调试和监视查询、突变和缓存状态。它提供了一个可视化界面来检查查询的详细信息并查看 react query 如何管理其生命周期。

8. 服务器端渲染(ssr)

  • react query 支持服务器端渲染(ssr),这有助于在将数据发送到客户端之前在服务器上预取数据。这使得初始页面加载速度更快,并且可以通过向搜索引擎提供完全渲染的页面来改进 seo。

如何实现 react 查询

这是有关如何使用 react query 来管理 react 应用程序中的服务器数据获取、缓存、更新和同步的分步指南。

第 1 步:安装 react 查询

首先,将 react query 添加到您的项目中:

npm install @tanstack/react-query

第 2 步:设置 queryclientprovider

要配置 react query,请将您的应用程序包装在 queryclientprovider 中。该提供程序使用 queryclient 实例,该实例管理缓存、后台获取和更新。

import { queryclient, queryclientprovider } from '@tanstack/react-query';

const queryclient = new queryclient();

function app() {
  return (
    <queryclientprovider client={queryclient}>
      <yourcomponent />
    </queryclientprovider>
  );
}

第 3 步:使用 usequery 获取数据

usequery 挂钩从 api 获取数据,自动缓存数据并处理加载和错误等状态。

新快购物系统
新快购物系统

新快购物系统是集合目前网络所有购物系统为参考而开发,不管从速度还是安全我们都努力做到最好,此版虽为免费版但是功能齐全,无任何错误,特点有:专业的、全面的电子商务解决方案,使您可以轻松实现网上销售;自助式开放性的数据平台,为您提供充满个性化的设计空间;功能全面、操作简单的远程管理系统,让您在家中也可实现正常销售管理;严谨实用的全新商品数据库,便于查询搜索您的商品。

下载
import { usequery } from '@tanstack/react-query';

function yourcomponent() {
  const { data, error, isloading } = usequery(['todos'], fetchtodos);

  if (isloading) return <p>loading...</p>;
  if (error) return <p>error: {error.message}</p>;

  return (
    <div>
      {data.map((todo) => (
        <p key={todo.id}>{todo.title}</p>
      ))}
    </div>
  );
}

// sample fetch function
const fetchtodos = async () => {
  const response = await fetch('/api/todos');
  return response.json();
};
  • key (['todos']):每个 usequery 都需要一个唯一的 key 来识别和缓存数据。
  • 查询函数 (fetchtodos):此异步函数从 api 获取您需要的数据。

第 4 步:使用 usemutation 处理数据突变

usemutation 钩子用于创建、更新或删除数据。突变成功后,您可以使用查询失效来重新获取相关数据并使应用程序的状态保持最新。

import { usemutation, usequeryclient } from '@tanstack/react-query';

function todoadder() {
  const queryclient = usequeryclient();
  const addtodomutation = usemutation(addtodo, {
    onsuccess: () => {
      queryclient.invalidatequeries(['todos']);
    },
  });

  return (
    <button onclick={() => addtodomutation.mutate({ title: 'new todo' })}>
      add todo
    </button>
  );
}

const addtodo = async (newtodo) => {
  const response = await fetch('/api/todos', {
    method: 'post',
    headers: {
      'content-type': 'application/json',
    },
    body: json.stringify(newtodo),
  });
  return response.json();
};
  • 突变函数 (addtodo):此异步函数修改服务器状态。
  • onsuccess:突变后,此回调使 ['todos'] 查询无效,重新获取并更新数据以显示新添加的待办事项。

第 5 步:用于调试的可选开发工具

react query devtools 可以帮助您在开发过程中监控查询、缓存状态等:

npm install @tanstack/react-query-devtools

然后,将 添加到您的应用程序中:

import { ReactQueryDevtools } from '@tanstack/react-query-devtools';

function App() {
  return (
    <QueryClientProvider client={queryClient}>
      <YourComponent />
      <ReactQueryDevtools initialIsOpen={false} />
    </QueryClientProvider>
  );
}

结论

使用 react query 替换 useeffect 来获取数据和产生副作用,这是构建现代 react 应用程序的一个很好的建议。

react query 改变了您在 react 应用程序中处理服务器端数据的方式,提供了一种更具声明性的方法来简化复杂的状态管理。通过利用其强大的功能(例如缓存、后台同步和查询失效),您可以创建高度响应和高性能的应用程序。最后但并非最不重要的一点是,集成 react query devtools 可以轻松监控和调试,确保应用程序的数据流顺畅且透明。

无论您是构建简单的单页应用程序还是复杂的数据密集型应用程序,react query 都可以让您轻松构建更快、更智能、更用户友好的应用程序。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1558

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

642

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1027

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

980

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

186

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

89

2025.08.07

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

15

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号