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>
)
}
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>
)
}