框架
版本

概述

TanStack Query(前称 React Query)通常被描述为 Web 应用程序中缺失的数据获取库,但更技术性地说,它使在您的 Web 应用程序中获取、缓存、同步和更新服务器状态变得轻而易举。

动机

大多数核心 Web 框架没有提供一种固执己见的方式来整体地获取或更新数据。因此,开发人员最终构建了元框架(其中封装了关于数据获取的严格意见),或者他们发明了自己的数据获取方式。这通常意味着拼凑基于组件的状态和副作用,或者使用更通用的状态管理库来存储和提供整个应用程序的异步数据。

虽然大多数传统状态管理库非常适合处理客户端状态,但它们不太擅长处理异步或服务器状态。这是因为服务器状态完全不同。首先,服务器状态

  • 远程持久化在您可能不控制或拥有的位置
  • 需要异步 API 来获取和更新
  • 意味着共享所有权,并且可能在您不知情的情况下被其他人更改
  • 如果您不小心,可能会在您的应用程序中变得“过时”

一旦您掌握了应用程序中服务器状态的性质,随着您的深入,甚至会涌现出更多挑战,例如

  • 缓存...(可能是编程中最难做的事情)
  • 将对相同数据的多个请求去重为一个请求
  • 在后台更新“过时”数据
  • 知道数据何时“过时”
  • 尽可能快地反映数据更新
  • 性能优化,例如分页和延迟加载数据
  • 管理服务器状态的内存和垃圾回收
  • 使用结构共享记忆查询结果

如果您没有被这个列表吓倒,那么这一定意味着您可能已经解决了所有服务器状态问题,并且应该获得奖励。但是,如果您像绝大多数人一样,那么您要么尚未解决所有或大部分这些挑战,而我们才刚刚开始触及皮毛!

TanStack Query 绝对是管理服务器状态的最佳库之一。它开箱即用,零配置,并且可以自定义以满足您的喜好,随着您的应用程序的增长。

TanStack Query 允许您战胜和克服服务器状态的棘手挑战和障碍,并在您的应用数据开始控制您之前控制它。

从更技术的角度来看,TanStack Query 可能会

  • 帮助您从应用程序中删除许多行复杂且容易被误解的代码,并用几行 TanStack Query 逻辑替换。
  • 使您的应用程序更易于维护,并且更易于构建新功能,而无需担心连接新的服务器状态数据源
  • 通过使您的应用程序感觉比以往更快、响应更快,对您的最终用户产生直接影响。
  • 可能有助于您节省带宽并提高内存性能

少说废话,快给我看代码!

在下面的示例中,您可以看到 TanStack Query 以其最基本和最简单的形式被用于获取 TanStack Query GitHub 项目本身的 GitHub 统计信息

在 StackBlitz 中打开

tsx
import {
  QueryClient,
  QueryClientProvider,
  useQuery,
} from '@tanstack/react-query'

const queryClient = new QueryClient()

export default function App() {
  return (
    <QueryClientProvider client={queryClient}>
      <Example />
    </QueryClientProvider>
  )
}

function Example() {
  const { isPending, error, data } = useQuery({
    queryKey: ['repoData'],
    queryFn: () =>
      fetch('https://api.github.com/repos/TanStack/query').then((res) =>
        res.json(),
      ),
  })

  if (isPending) return 'Loading...'

  if (error) return 'An error has occurred: ' + error.message

  return (
    <div>
      <h1>{data.name}</h1>
      <p>{data.description}</p>
      <strong>👀 {data.subscribers_count}</strong>{' '}
      <strong>✨ {data.stargazers_count}</strong>{' '}
      <strong>🍴 {data.forks_count}</strong>
    </div>
  )
}
import {
  QueryClient,
  QueryClientProvider,
  useQuery,
} from '@tanstack/react-query'

const queryClient = new QueryClient()

export default function App() {
  return (
    <QueryClientProvider client={queryClient}>
      <Example />
    </QueryClientProvider>
  )
}

function Example() {
  const { isPending, error, data } = useQuery({
    queryKey: ['repoData'],
    queryFn: () =>
      fetch('https://api.github.com/repos/TanStack/query').then((res) =>
        res.json(),
      ),
  })

  if (isPending) return 'Loading...'

  if (error) return 'An error has occurred: ' + error.message

  return (
    <div>
      <h1>{data.name}</h1>
      <p>{data.description}</p>
      <strong>👀 {data.subscribers_count}</strong>{' '}
      <strong>✨ {data.stargazers_count}</strong>{' '}
      <strong>🍴 {data.forks_count}</strong>
    </div>
  )
}

你说服我了,然后呢?