默认查询函数
如果你因为某种原因希望为整个应用共享同一个查询函数,仅使用查询键(query keys)来标识需要获取的内容,你可以通过向 TanStack Query 提供一个默认查询函数来实现:
// 定义一个默认查询函数,它将接收查询键
const defaultQueryFn = async ({ queryKey }) => {
const { data } = await axios.get(
`https://jsonplaceholder.typicode.com${queryKey[0]}`,
)
return data
}
// 通过 defaultOptions 将默认查询函数提供给你的应用
const queryClient = new QueryClient({
defaultOptions: {
queries: {
queryFn: defaultQueryFn,
},
},
})
function App() {
return (
<QueryClientProvider client={queryClient}>
<YourApp />
</QueryClientProvider>
)
}
// 现在你只需传递一个键即可!
function Posts() {
const { status, data, error, isFetching } = useQuery({ queryKey: ['/posts'] })
// ...
}
// 你甚至可以省略 queryFn,直接进入选项
function Post({ postId }) {
const { status, data, error, isFetching } = useQuery({
queryKey: [`/posts/${postId}`],
enabled: !!postId,
})
// ...
}如果你想覆盖默认的 queryFn,只需像平常一样提供你自己的函数即可。
最后更新于
这有帮助吗?