当「状态」需要跨组件层级传递,通常使用Context API。 再大范围的「状态」会使用Redux这样的「全局状态管理方案」。...这里,推荐使用React-Query管理服务端状态。 ? 另一个可选方案是SWR[1]。...我们可以将刚才的例子用React-Query改写: import { useQuery } from 'react-query' function App() { const {data,...不仅如此,React-Query还为我们做了如下工作: 多个组件请求同一个query时只发出一个请求 缓存数据失效/更新策略(判断缓存合适失效,失效后自动请求数据) 对失效数据垃圾清理 数据的CRUD由...这样,React-Query就会重新请求userData对应query的数据。 总结 通过使用React-Query(或SWR)这样的数据请求库,可以将服务端状态从全局状态中解放出来。
,需要使用其返回的“refetch”来触发操作 queryFn:全局定义请求方法,其他地方使用时只需要直接传入请求参数 useQuery useQuery是React-Query提供的用于请求接口并管理请求状态等信息的...在使用的时候会自动把它拼接为/repoData/1,这个在缓存用户访问过的页面时,非常有用。...除此之外,使用useQuery拉取回来的数据,会被默认缓存起来,然后可以通过配置过期时间,重新拉取等策略来进行管理。...最后 感谢你能看到这里,本文简单介绍了React-Query对服务端数据进行增删改查的功能实现,以及React-Query的一些其他能力,希望对你有用,React-Query的使用场景没有其他状态管理库那么广泛...笔者之后也会继续更新React-Query的其他使用场景,如果可以的话,不妨点个赞再走呢,这对我很重要。
的star数量 axios .get("https://api.github.com/repos/tannerlinsley/react-query") .then((res...const { data, isLoading, error } = useQuery("getStar", () => axios.get("https://api.github.com/repos...Mutations useMutation:用来创建、更新、删除数据,当你的接口涉及这些逻辑时你可以使用它。...复制代码 Mutation(突变) 用来创建/更新/删除数据时使用,最典型的例子就是一个todoList,对todo进行增删改相关的请求。使用useMutation hooks。...("repoData", () => fetch( "https://api.github.com/repos/tannerlinsley/react-query" ).then
在之前,了解了如何设置模拟 API,而在本节中,将学习如何通过应用程序消费 API。当我们提到 API 时,指的是 API 后端服务。...对于每个 API 请求,我们都将有一个文件,其中包含并导出 API 请求定义函数和用于在 React 中使用请求的 hook。...对于请求定义函数,我们将使用我们刚刚创建的 axios client,对于 hooks,我们将使用 React Query 的 hooks。...# 职位相关 Jobs 获取职位列表 // src/features/jobs/api/get-jobs.ts import { useQuery } from "@tanstack/react-query...API 层 之前为了在没有 API 功能的情况下构建 UI,我们在页面上使用了测试数据。
有几种方法可以将此数据发送/获取到 API 或服务器,可以使用内置的 API 或外部 npm 包来实现。 # fetch 这是 JavaScript 和 React 应用程序中常用的 API。...Memoization 函数通常更快,因为如果使用相同的参数再次调用函数,则不会重新执行函数,而是从缓存中获取结果。...从 API 缓存的数据可以存储在我们的状态管理中,然后在我们的应用程序中全局使用。尽管数据被缓存,但在刷新页面时,它将丢失数据,需要重新获取。...# 安装 npm install react-query # 使用 import React from "react"; import { useQuery, QueryClient, QueryClientProvider..., error, data } = useQuery("repoData", () => fetch("https://api.github.com/repos/tannerlinsley/react-query
另外,如果你使用的是 GraphQ L,还可以考虑使用 Apollo 之类的其他不错的选择。这篇文章假设你正在调用传统的 REST API。 方式1:内联 这是最简单,最直接的选择。...使用这种方法,我们创建了一个名为 services 的文件夹,并且把进行 HTTP 调用的函数都放进去。...其思想是这样的:当相关函数一起处理时,更容易一致地处理它们。如果 userService 文件夹中充满了进行 HTTP 调用的函数,那么我可以很容易地确保它们始终如一地这样做。...但是,您应该只需要方式4: 方式4:react-query/swr 使用 react-query或swr,可以为我们处理缓存、重试、重复查询等等。我不必维护自己的自定义Hook了。.../services/userService"; import { useQuery } from "react-query"; export default function ReactQueryDemo
你将在本系列中发现更多关于它的内容,学习如何使用它,并欣赏其在 React 应用程序中的简洁性。 useQuery 第一个核心概念是 useQuery。...让我们看一个例子: import { useQuery } from '@tanstack/react-query'; const fetchTodos = async (): Promise<Todo...这个 hook 的结果有三个重要的属性: data:此属性包含查询函数的结果。请注意数据也可能为 undefined;这是因为在第一次调用时,当请求处于等待状态时,data 尚未呈现。...当你开始学习或使用一个工具时,检查它周围的工具以了解开发者体验是很正常的,这样你就可以决定是否继续使用它。...使用 QueryClient,您可以使用 setQueryData 函数设置特定查询的数据。
目前,当涉及到管理控制台中的用户身份验证时,应用程序仍然依赖于测试数据。在本节中,我们将构建应用程序的身份验证系统,允许用户认证并访问受保护的资源在管理控制台中。...我们还将创建一个 toast 通知系统,以便在发生我们希望通知用户的操作时向他们提供反馈。...除了响应数据之外,还将附加一个 httpOnly cookie,从此时起用于身份验证请求 每当用户进行身份验证时,我们将从响应中的用户对象存储在 react-query 缓存中,并使其对应用程序可用 由于身份验证是基于...import { useMutation } from "@tanstack/react-query"; import { apiClient } from "@/lib/api-client";.../get-auth-user.ts import { useQuery } from "@tanstack/react-query"; import { apiClient } from "@/lib
Redux 不是缓存 使用 Redux 和类似的状态管理库时,大多数人都会遇到的一大问题是,我们会将其视为后端状态的缓存。...React Query 我已经在自己的多数个人和工作项目中使用 React Query 几个月了。这个库有一个非常简单的 API 和几个 hooks,用于管理查询(获取数据)和突变(更改数据)。...下面是使用 React Query 实现的相同示例: import React from "react"; import { useQuery } from "react-query"; import...只要函数是异步的,实现就无关紧要——你可以轻松地使用 Fetch API 代替 Axios。 要更改后端状态时,React Query 提供了 useMutation hook。...React Query 和 SWR 大约是在同一时间开始开发的,并且以积极的方式相互影响。在 react-query 文档中也对这两个库进行了彻底的比较。
虽然像Redux这样的库是管理应用程序状态的流行选择,但你应该明白何时使用它们,何时不使用它们,而且在满足需求时考虑像Context API这样的简单替代方案也很重要。...当单击增量或减量按钮时,我们使用dispatch函数分派相应的动作。利用React Query进行服务器状态管理对于涉及服务器端状态管理(如数据获取和缓存)的情景,我们引入React Query。...import React from 'react';import { useQuery, useMutation, QueryClient, QueryClientProvider } from 'react-query...我们定义了一个postData函数,用于向服务器保存新数据的POST请求。在DataComponent中,我们使用useQuery钩子使用fetchData函数获取数据。...像Context API这样的简单解决方案通常足以满足较小项目的要求,并避免不必要的复杂性。通过理解不同状态管理方法的优势和权衡,您可以在选择正确解决方案时做出明智的决策。
,显示到页面上 // 通过 id 获取项目信息 export const useProjectInUrl = () => useProject(useProjectIdInUrl()) 使用 const...其实在我们在遍历添加 kanbanColumns 组件时,只会发起一个请求,即使,我们给每一个 column 都绑定了 useTask 这是因为,我们采用的 react-query 的功劳,在我们采用...useQuery 时,如果在 2s 之内有相同的 queryKey 发出请求的话,就会合并这些请求,只会发出一个 现在我们已经有了每个看板下的 Task 数据了,我们只需要遍历渲染即可,这里我们采用的还是...重置按钮 在这里勇个比较有意思的按钮,清楚筛选器,它实现的方法请求非常的简单,我们只需要将所有的数据重置为 undefined ,我们的 clean 函数,就会讲 query 修理为空,这样我们返回的数据就会是全部的数据...的用法 对 modal 组件有了更多的了解 了解了 react-query 能够优化请求次数
暂时没有使用过,不做展开介绍。 SWR[6]、React-Query[7]、useRequest[8],网络请求的状态管理、缓存、竞态处理等。...同样是淘系到集团广泛使用的跨端方案。 Remax[19],小程序跨端框架,基于React,亮点是运行时方案(大部分跨端方案都是编译时,还有Rax这种两套方案都支持的)。...GraphiQL[45],可视化的GraphQL API调试工具,直观的查看你的Schema、发起请求、查看问题,有一个增强版本是支持通过点击单选框生成查询语句,一时没找到。...Hasura[53],功能比较全的一款,支持PostgreSQL和MSSQL,除了上面提到的以外还提供鉴权与触发器(类似Serverless中的触发器),以及把外部已经独立部署的GraphQL API也纳入管控...GraphQL-Voyager[108],可视化你的GraphQL API,比如我的这个demo: Voyager[109]。 Majestic[110],Jest的GUI,直观的查看你的测试用例。
暂时没有使用过,不做展开介绍。 SWR、React-Query、useRequest,网络请求的状态管理、缓存、竞态处理等。 生态 GatsbyJS,基于React的静态页面生成器,非常快。...同样是淘系到集团广泛使用的跨端方案。 Remax,小程序跨端框架,基于React,亮点是运行时方案(大部分跨端方案都是编译时,还有Rax这种两套方案都支持的)。...GraphiQL,可视化的GraphQL API调试工具,直观的查看你的Schema、发起请求、查看问题,有一个增强版本是支持通过点击单选框生成查询语句,一时没找到。...Hasura,功能比较全的一款,支持PostgreSQL和MSSQL,除了上面提到的以外还提供鉴权与触发器(类似Serverless中的触发器),以及把外部已经独立部署的GraphQL API也纳入管控...GraphQL-Voyager,可视化你的GraphQL API,比如我的这个demo: Voyager。 Majestic,Jest的GUI,直观的查看你的测试用例。
它允许您使用类似本地函数调用的方式来调用远程函数,同时自动处理序列化和反序列化、错误处理和通信协议等底层细节。...时,将会提示出服务端定义好的 greeting 函数,如下图所示。...文档: useQuery() | tRPC不妨此时打开控制台面板,看看请求图片图片不难看出,调用 greeting 函数本质是向 /api/trpc/greeting 发送了 http 请求,并且携带参数...然后调用 greeting 函数时,通过通过函数参数的形式来传递请求参数。...(不过我比较好奇为啥好多远程数据服务多数都是postgresql)如果你执意要使用 vercel 部署,当你触发数据库服务时便会报错,以下是相关截图。
# 单元测试 单元测试是在应用程序单元在不依赖于其他部分的情况下进行独立测试。 对于单元测试,我们将使用 Jest,它是 JavaScript 应用程序最流行的测试框架。...我们还应该从这里重新导出 React Testing Library 提供的所有实用工具,以便我们在测试中需要它们时可以轻松地使用它们。...等等 提供 AppProvider 作为 wrapper 将在我们进行测试时用于渲染组件 checkTableValues 是一个函数,它遍历表格中的所有单元格,并将每个值与提供的数据中的相应值进行比较...,以确保所有信息都在表格中显示 waitForLoadingToFinish 是一个函数,在我们进行测试之前,它会等待所有加载提示消失 可应用于当我们必须等待某些数据被获取后才能断言值时 // src...在我们的情况下,它帮助我们在测试之间初始化和重置模拟的 API。
2.2 单元测试分类 TDD - (测试驱动开发)侧重点偏向开发,通过测试用例来规范约束开发者编写出质量更高、bug更少的代码 BDD - (行为驱动开发) 由外到内的开发方式,从外部定义业务成果,再深入到能实现这些成果...Jest 运用 Jest 是 Facebook 开源的一款 JS 单元测试框架,它也是 React 目前使用的单元测试框架,目前vue官方也把它当作为单元测试框架官方推荐 。...我在项目开发使用jest作为单元测试框架,结合vue官方的测试工具vue-util-test 3.1 Jest 安装 npm install --save-dev jest npm install -g...}); 3.5.4 mock函数 三个与 Mock 函数相关的API,分别是jest.fn()、jest.spyOn()、jest.mock() jest.fn() - 是创建Mock函数最简单的方式...踩坑点 1.触发事件 - 假设组件库使用的是iview中对提供的@change事件,但是当我们进行 wrapper.trigger('change')时,是触发不了的。
它允许您使用类似本地函数调用的方式来调用远程函数,同时自动处理序列化和反序列化、错误处理和通信协议等底层细节。...时,将会提示出服务端定义好的 greeting 函数,如下图所示。...文档: useQuery() | tRPC 不妨此时打开控制台面板,看看请求 不难看出,调用 greeting 函数本质是向 /api/trpc/greeting 发送了 http 请求,并且携带参数...然后调用 greeting 函数时,通过通过函数参数的形式来传递请求参数。...(不过我比较好奇为啥好多远程数据服务多数都是postgresql) 如果你执意要使用 vercel 部署,当你触发数据库服务时便会报错,以下是相关截图。
/src/utils'; // 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 jest.useFakeTimers(); // 描述块,将多个...() 作用: 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 这里使用jest.useFakeTimers()的目的就是暂停正在执行的timer...,但它们的值是一样的,也是可以的 小结 对于有返回值的function,就是通过判断「返回值」,是否与「期望值」相等即可 这样的好处: ① 当有新需求要扩展该函数时,可以保证该函数的返回值仍保持不变,进而不会影响到使用到该函数的旧需求...② 当测试的函数比较复杂时,非常方便,不用了解内部的详细代码,只需返回值符合期望即可 如何测试ReactComponent 当我写完一个React组件时,我该如何测试它呢?...props 测试用例 test('component props', () => { // jest.fn()建立 mock function // 进行单元测试时,应该将关注点放在
如果快照不匹配,则测试将失败。 # 使用 Cypress 进行端到端(e2e)测试 当涉及端到端测试时,Cypress 在其他框架/库中处于领先地位。...# 使用 Jest 进行集成测试 在大多数 React 应用程序中,通常需要与外部 API 集成以在应用程序中发布和获取数据。 可以使用 Jest 来测试 API 行为,以查看预期和意外结果。...Jest 模拟函数 使用 模拟函数 来侦测(查看)我们的函数被调用的情况,或者使用它来测试单个函数或整个模块。...React 组件的工具和函数 编写测试用例 编写完整的测试用例,覆盖组件的所有代码路径,包括正常情况和异常情况 使用快照测试 使用 Jest 中的快照测试功能来验证组件是否按预期呈现 使用模拟数据...使用模拟数据来测试组件,以确保它们在不同的数据情况下都能正常工作 使用模拟函数 使用模拟函数来模拟组件的依赖项和外部接口,以便更好地控制测试环境 集成测试 编写集成测试来测试应用程序的整个流程
领取专属 10元无门槛券
手把手带您无忧上云