'How can I get data from my store generated by RTK Query?
I'm using a very basic RTK Query hook to get some user data from an API. How can I access the data saved in my store inside of my components? I'm not able to get the data from the store generated in a specific matter by RTK Query.
I have a simple Post API and I called the getPosts hook. In Redux devtools I can see the data from the RTK query hook in my store:
Post API
import { createApi, fetchBaseQuery } from '@rtk-incubator/rtk-query';
export interface Post {
id: number;
name: string;
fetched_at: string;
}
type PostsResponse = Post[];
export const postApi = createApi({
reducerPath: 'postsApi',
baseQuery: fetchBaseQuery({ baseUrl: '/' }),
entityTypes: ['Posts'],
endpoints: (build) => ({
getPosts: build.query<PostsResponse, void>({
query: () => 'posts',
provides: (result) => [
...result.map(({ id }) => ({ type: 'Posts', id } as const)),
{ type: 'Posts', id: 'LIST' },
],
}),
}),
});
Posts saved in store after hook was called
Solution 1:[1]
You can access data and status try this:
const result = api.endpoints.getPosts.select()(state)
const { data, status, error } = result
and call api without hook:
dispatch(api.endpoints.getPosts.initiate())
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | Dipanjan Panja |

