TanStack Query(以前称为 React Query)通常被描述为 Web 应用程序中缺失的数据获取库,但从更技术性的角度来说,它使获取、缓存、同步和更新服务器状态在您的 Web 应用程序中变得轻而易举。
大多数核心 Web 框架不自带一种整体性的数据获取或更新方式。因此,开发者最终会构建要么封装严格数据获取意见的元框架,要么发明自己的数据获取方式。这通常意味着将基于组件的状态和副作用组合在一起,或者使用更通用的状态管理库来存储和提供应用程序中的异步数据。
虽然大多数传统的状态管理库非常适合处理客户端状态,但它们不太适合处理异步或服务器状态。这是因为服务器状态完全不同。首先,服务器状态
一旦您掌握了应用程序中服务器状态的本质,**甚至会出现更多挑战**,例如
如果您没有被上述列表压垮,那么一定意味着您可能已经解决了所有服务器状态问题,并值得获得奖励。但是,如果您像绝大多数人一样,您要么尚未解决所有或大多数这些挑战,或者我们只是触及了表面!
TanStack Query 绝对是管理服务器状态的*最佳*库之一。它**开箱即用,零配置,并且可以根据您的喜好进行定制**,随着应用程序的增长而不断发展。
TanStack Query 允许您战胜和克服*服务器状态*的棘手挑战和障碍,并在应用程序数据开始控制您之前控制它。
更技术性地说,TanStack Query 很可能会
在下面的示例中,您可以看到 TanStack Query 以最基本和最简单的方式被用来获取 TanStack Query GitHub 项目本身的 GitHub 统计信息
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>
)
}