QueryCache 是 TanStack Query 的存储机制,用于存储其包含的所有查询数据、元信息和状态。
通常情况下,您不会直接与 QueryCache 交互,而是通过 QueryClient 来操作特定缓存。
import { QueryCache } from '@tanstack/react-query'
const queryCache = new QueryCache({
onError: (error) => {
console.log(error)
},
onSuccess: (data) => {
console.log(data)
},
onSettled: (data, error) => {
console.log(data, error)
},
})
const query = queryCache.find(['posts'])
import { QueryCache } from '@tanstack/react-query'
const queryCache = new QueryCache({
onError: (error) => {
console.log(error)
},
onSuccess: (data) => {
console.log(data)
},
onSettled: (data, error) => {
console.log(data, error)
},
})
const query = queryCache.find(['posts'])
其提供的方法包括:
配置项
find 是一个略微高级的同步方法,可用于从缓存中获取现有的查询实例。该实例不仅包含查询的所有状态,还包括所有实例和查询的底层实现细节。如果查询不存在,则返回 undefined。
注意:大多数应用通常不需要此方法,但在需要获取查询更多信息的罕见场景中会很有用(例如通过检查 query.state.dataUpdatedAt 时间戳来决定查询数据是否足够新鲜可用作初始值)
const query = queryCache.find(queryKey)
const query = queryCache.find(queryKey)
配置项
返回值
findAll 是更高级的同步方法,可用于从缓存中获取部分匹配查询键的所有现有查询实例。如果查询不存在,则返回空数组。
注意:大多数应用通常不需要此方法,但在需要获取查询更多信息的罕见场景中会很有用
const queries = queryCache.findAll(queryKey)
const queries = queryCache.findAll(queryKey)
配置项
返回值
subscribe 方法可用于订阅整个查询缓存,并在缓存发生安全/已知的更新时(如查询状态变更、查询被更新/添加/删除)接收通知
const callback = (event) => {
console.log(event.type, event.query)
}
const unsubscribe = queryCache.subscribe(callback)
const callback = (event) => {
console.log(event.type, event.query)
}
const unsubscribe = queryCache.subscribe(callback)
配置项
返回值
clear 方法可用于完全清空缓存并重新开始。
queryCache.clear()
queryCache.clear()
要更深入理解 QueryCache 的内部工作原理,请参阅社区资源中的 #18: React Query 内部机制。