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 делает автоматически, - это повторная выборка, чего должно быть более чем достаточно в большинстве случаев использования.

Другие вопросы по тегам