Redux RTK Query: недействительность только одного элемента из списка
У меня есть следующий API, определенный для запроса RTK:
export const postsApi = createApi({
reducerPath: "postsApi",
baseQuery: fetchBaseQuery({ baseUrl: 'https://myservice.co/api/v2/' }),
tagTypes: ["Posts"],
endpoints: (builder) => ({
getAllPosts: builder.query({
query: () => ({ method: "GET", url: "/posts" }),
transformResponse: (response) => response.posts,
providesTags: (result) =>
result
? [
...result.map(({ id }) => ({ type: "Posts", id })),
{ type: "Posts", id: "LIST" },
]
: [{ type: "Posts", id: "LIST" }],
}),
updatePost: builder.mutation({
query: ({ postId, ...body }) => ({
url: `/posts/${postId}`,
method: "POST",
config: { body },
}),
invalidatesTags: (_, __, arg) => [{ type: "Posts", id: arg.id }],
}),
getPost: builder.query({
query: (postId) => ({
method: "GET",
url: `/posts/${postId}`,
}),
providesTags: (_, __, id) => [{ type: "Posts", id }],
}),
}),
});
export const { useGetAllPostsQuery, useUpdatePostMutation, useGetPostQuery } = postsApi;
Я бы хотел, чтобы при успешном вызове updatePost он только аннулировал кеш для одного сообщения и использовал запрос getPost для повторной выборки информации вместо getAllPosts. Это вообще возможно? Сообщения отображаются в таблице, полученной с помощью запроса getAllPosts.
1 ответ
Нет. RTK-Query - это кэш документов (полный ответ = документ), а не нормализованный кеш. Он ничего не знает о содержимом кешированных ответов и их структуре - и никогда не будет пытаться «сшить» что-либо самостоятельно.
Вы можете сделать это вручную с оптимистичным обновлением, но все, что RTK-Q делает автоматически, - это повторная выборка, чего должно быть более чем достаточно в большинстве случаев использования.