TanStackQuery:React
TanStack Query의 React 버전. (aka. react-query)
stale
APIs
useQuery
useQueryClient
useMutation
- (React) React Query 비동기 작업 처리하기 (useEffect → useQuery → useMutation)
- (React Query) 리액트 쿼리 useMutation 기본 편
Example
import {
useQuery,
useMutation,
useQueryClient,
QueryClient,
QueryClientProvider,
} from '@tanstack/react-query'
import { getTodos, postTodo } from '../my-api'
// Create a client
const queryClient = new QueryClient()
function App() {
return (
// Provide the client to your App
<QueryClientProvider client={queryClient}>
<Todos />
</QueryClientProvider>
)
}
function Todos() {
// Access the client
const queryClient = useQueryClient()
// Queries
const query = useQuery({ queryKey: ['todos'], queryFn: getTodos })
// Mutations
const mutation = useMutation({
mutationFn: postTodo,
onSuccess: () => {
// Invalidate and refetch
queryClient.invalidateQueries({ queryKey: ['todos'] })
},
})
return (
<div>
<ul>
{query.data?.map((todo) => (
<li key={todo.id}>{todo.title}</li>
))}
</ul>
<button
onClick={() => {
mutation.mutate({
id: Date.now(),
title: 'Do Laundry',
})
}}
>
Add Todo
</button>
</div>
)
}
render(<App />, document.getElementById('root'))
Troubleshooting
Query data cannot be undefined
Query data cannot be undefined. Please make sure to return a value other than undefined from your query function. Affected query key: ["summary"]
See also
- TanStack Query
- SWR (stale-while-revalidate)