TanStack Query 的核心功能是根据查询键为你管理查询缓存。查询键必须是顶级数组,可以像包含单个字符串的数组一样简单,也可以像包含多个字符串和嵌套对象的数组一样复杂。只要查询键可以使用 JSON.stringify 序列化,并且对于查询的数据是唯一的,你就可以使用它!
最简单的键形式是包含常量值的数组。这种格式适用于
// A list of todos
useQuery({ queryKey: ['todos'], ... })
// Something else, whatever!
useQuery({ queryKey: ['something', 'special'], ... })
// A list of todos
useQuery({ queryKey: ['todos'], ... })
// Something else, whatever!
useQuery({ queryKey: ['something', 'special'], ... })
当查询需要更多信息来唯一描述其数据时,你可以使用包含一个字符串和任意数量可序列化对象的数组来描述它。这对于以下情况很有用
// An individual todo
useQuery({ queryKey: ['todo', 5], ... })
// An individual todo in a "preview" format
useQuery({ queryKey: ['todo', 5, { preview: true }], ...})
// A list of todos that are "done"
useQuery({ queryKey: ['todos', { type: 'done' }], ... })
// An individual todo
useQuery({ queryKey: ['todo', 5], ... })
// An individual todo in a "preview" format
useQuery({ queryKey: ['todo', 5, { preview: true }], ...})
// A list of todos that are "done"
useQuery({ queryKey: ['todos', { type: 'done' }], ... })
这意味着无论对象中键的顺序如何,以下所有查询都被认为是相等的
useQuery({ queryKey: ['todos', { status, page }], ... })
useQuery({ queryKey: ['todos', { page, status }], ...})
useQuery({ queryKey: ['todos', { page, status, other: undefined }], ... })
useQuery({ queryKey: ['todos', { status, page }], ... })
useQuery({ queryKey: ['todos', { page, status }], ...})
useQuery({ queryKey: ['todos', { page, status, other: undefined }], ... })
然而,以下查询键不相等。数组项的顺序很重要!
useQuery({ queryKey: ['todos', status, page], ... })
useQuery({ queryKey: ['todos', page, status], ...})
useQuery({ queryKey: ['todos', undefined, page, status], ...})
useQuery({ queryKey: ['todos', status, page], ... })
useQuery({ queryKey: ['todos', page, status], ...})
useQuery({ queryKey: ['todos', undefined, page, status], ...})
由于查询键唯一地描述了它们正在获取的数据,因此它们应该包含你在查询函数中使用的会发生变化的任何变量。例如
function Todos({ todoId }) {
const result = useQuery({
queryKey: ['todos', todoId],
queryFn: () => fetchTodoById(todoId),
})
}
function Todos({ todoId }) {
const result = useQuery({
queryKey: ['todos', todoId],
queryFn: () => fetchTodoById(todoId),
})
}
请注意,查询键充当查询函数的依赖项。将依赖变量添加到查询键将确保查询独立缓存,并且每次变量更改时,查询将自动重新获取(取决于你的 staleTime 设置)。有关更多信息和示例,请参阅 exhaustive-deps 部分。
有关在大型应用程序中组织查询键的技巧,请参阅 高效的 React Query 键,并查看社区资源中的 查询键工厂包。