- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 Ionic React 应用程序中使用 react-query
3.30。
我有一个分页查询:
export function useCardAdmin(
currentJsonUrl: string,
): UseQueryResult<JsonDataWidgetPagerRead, Error> {
const query = currentJsonUrl;
const queryKey = queryKeyUseWidgetAdmin(currentJsonUrl);
return useQuery<JsonDataWidgetPagerRead, Error>(
queryKey,
async () => fetchAuth(query, true),
{
keepPreviousData: true,
staleTime: DAY_MILLISECONDS,
cacheTime: DAY_MILLISECONDS,
},
);
}
export const queryKeyUseWidgetAdmin = (currentJsonUrl: string): string => (`getWidgetAdmin${currentJsonUrl}`);
这工作正常。
典型的查询键值为 getCardsAdminhttps://example.com/jsonapi/widgets?&fields[widget]=id,drupalId,part,gadget,refGroup&filter[uid.id][value]=adadfasf-f992 -489c-9519-038f1728e0db&sort=-created&page[limit]=25
但是,当用户更新小部件(PATCH 到服务器)时,我需要使查询无效。
所以我尝试了这个:
queryClient.invalidateQueries('getWidgetAdmin')
我希望所有以 getWidgetAdmin
开头的查询都无效 because the documentation says that the argument to invalidateQueries is treated as a prefix .但是,它们都没有失效。
如果我使用确切的查询键,像这样:
queryClient.invalidateQueries(queryKeyUseWidgetAdmin(currentJsonUrl))
则查询无效。但我想使所有以 getWidgetAdmin
开头的查询无效,而不仅仅是其中一个。
我也试过设置exact
:
queryClient.invalidateQueries('getWidgetAdmin', { exact: false })
这也没有用。
如何使 react-query
中的一组查询无效?
附加信息:
我正在使用一些自定义配置初始化 QueryClient()
,但即使我在没有任何配置的情况下初始化 queryClient
(const queryClient = new QueryClient();
),我仍然遇到同样的问题。
最佳答案
模糊查询键匹配只对数组有效。因此,如果您的 key 是:
['getWidgetAdmin', some, more, filters]
您可以模糊地使无效:
queryClient.invalidateQueries(['getWidgetAdmin'])
如果它确实需要是一个字符串 startsWith,您可以提供一个谓词函数(参见 QueryFilters documentation):
queryClient.invalidateQueries({
predicate: (query) => query.queryKey.startsWith('getWidgetAdmin')})
关于react-query invalidateQueries 不适用于前缀/URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69785132/
我在 Ionic React 应用程序中使用 react-query 3.30。 我有一个分页查询: export function useCardAdmin( currentJsonUrl: s
我在Vue有这个组件。当我保存时,服务器将返回更新的记录。因此,我不需要再向服务器发送另一个请求。然而,这触发了新的GET:。我是VUE-QUERY的新手。我意识到缓存需要作废。然而.。当它失效时,有
我在Vue有这个组件。当我保存时,服务器将返回更新的记录。因此,我不需要再向服务器发送另一个请求。然而,这触发了新的GET:。我是VUE-QUERY的新手。我意识到缓存需要作废。然而.。当它失效时,有
我是一名优秀的程序员,十分优秀!