4.11 바로 투두 삭제가 안됨 질문
투두 삭제할 때 mutation 부분 코드를 강의와 똑같이
// use-delete-todo-mutation.ts
export function useDeleteTodoMutation() {
const queryClient = useQueryClient();
return useMutation({
mutationFn: deleteTodo,
onSuccess: (deletedTodo) => {
queryClient.setQueryData<Todo[]>(QUERY_KEYS.todo.list, (prevTodos) => {
if (!prevTodos) return [];
return prevTodos.filter((prevTodo) => prevTodo.id !== deletedTodo.id);
});
},
});
}
이렇게 치면 바로 삭제가 안 되고 새로고침해야 적용이되는데
export function useDeleteTodoMutation() {
const queryClient = useQueryClient();
return useMutation({
mutationFn: deleteTodo,
onSuccess: (_data, deletedId) => {
queryClient.setQueryData<Todo[]>(QUERY_KEYS.todo.list, (prevTodos) => {
if (!prevTodos) return [];
return prevTodos.filter((prevTodo) => prevTodo.id !== deletedId);
});
},
});
}이렇게 작성하면 바로 삭제 적용이 됩니다.
무슨 차이가 있는 걸까요?? 그리고 강의에 왜 처음 코드는 바로 삭제 반영이 안 되는 건지 궁금합니다 ㅜㅜ!
Answer 3
1
안녕하세요 보내주신 코드 잘 확인해봤습니다.
확인해보니 json-server의 버전이 과거의 버전으로 설치되어 있더군요
npm uninstall json-server로 제거하신 다음, npm i json-server로 최신 버전을 설치해 다시 사용해주시면 정상적으로 작동하게 될 겁니다 😀
0
안녕하세요 으악님 이정환입니다.
혹시 deleteTodo 함수의 반환값이 다음과 같이 잘 설정이 되어 있는 상황일까요?
import { API_URL } from "@/lib/constants";
import type { Todo } from "@/types";
export async function deleteTodo(id: string) {
const response = await fetch(`${API_URL}/todos/${id}`, {
method: "DELETE",
});
if (!response.ok) throw new Error("Delete Todo Failed");
const data: Todo = await response.json();
return data;
}강의에서 안내드린 것 처럼 deleteTodo 함수가 삭제된 아이템을 반환하지 않을 경우 onSuccess 함수에 매개변수로 삭제된 아이템이 제공되지 않을 수 있습니다. 이 부분을 확인해보셔야 할 듯 싶습니다.
0
넵 그렇게 되어있는데 안 되네요ㅜㅜ
혹시 패키지나 라이브러리 버전의 문제일까요?
현재 코드 상태 깃허브 주소 첨부드립니다!
0
안녕하세요, 인프런 AI 인턴입니다. 으악님.
질문에서 주신 문제는 deleteTodo 함수를 통한 mutation에서 onSuccess 콜백의 파라미터 사용 차이에서 비롯된 것 같습니다.
문제의 원인
첫 번째 코드:
onSuccess의 첫 번째 파라미터deletedTodo가 사용되었습니다. 이 경우는mutationFn(deleteTodo)의 반환 값을deletedTodo로 받습니다. 만약deleteTodo함수가 반환하는 데이터에id속성이 포함되어있지 않은 경우,deletedTodo.id는 예상대로 작동하지 않을 수 있습니다.두 번째 코드:
onSuccess의 두 번째 파라미터deletedId를 사용하셨습니다.deletedId는mutation.mutate호출 시 전달한 파라미터로, 삭제할 때 명시적으로 삭제할 ID를 가져와 사용합니다.
요약
- 첫 번째 코드에서는
deleteTodo함수의 반환 값에 따라deletedTodo.id를 사용할 수 있습니다. 만약deleteTodo에서 반환하는 객체가 예상과 다르다면, 빈 필터링 결과가 나오게 됩니다.
- 두 번째 코드에서는
mutation.mutate호출 시 넘겨준deletedId를 사용하여 안전하게 필터링 되며, 이 방식은deleteTodo함수의 반환 값에 의존하지 않습니다.
해결 방안
deleteTodo함수가 제대로된 객체(즉,id가 포함된)를 반환하는지 확인하거나, 두 번째 코드와 같이 명시적으로 ID를 사용할 수 있습니다.
이러한 차이로 인해 두 코드간에 동작 차이가 생긴 것으로 보입니다. 여러분의 이해를 돕기 위해 관련 질문 URL을 함께 공유드립니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
useMutation 적용 후 새로운 글 등록시 content가 안보여요
0
20
2
6.8 zustand 세션 질문입니다.
0
66
2
next.js 강의에서도 리액트 라이브러리들을 다뤄주시나요?
0
56
2
shadcn에서 radix ui와 base ui 차이는 뭔가요?
0
198
2
updateTodo 함수 생성시 화살표 함수 사용 안하는 이유
0
61
2
매개변수 updatedTodo 관련 질문
0
55
3
인증 정보가 만료되었을 때 라우트 가드 처리가 궁금합니다!
0
69
2
supabase를 사용하지 않을 경우 세션 데이터의 변경을 감지하고 스토어에 보관하는 방법이 궁금합니다!
0
58
2
4.6 id를 string으로 변경시 오류
0
53
2
리액트 타입스크립트 관련 질문있습니다.
0
52
1
소셜 로그인 구현하기 관련하여 질문이 있습니다!
0
86
2
ui 파일 질문드립니다.
0
62
1
tanstack query devtools에서 질문있습니다!
0
56
2
댓글 삭제 시 isPending 질문
0
54
2
두번째 예외상황에 대해 질문있습니다!
0
53
1
리액트 쿼리 질문입니다
0
56
2
개발자도구에서 components 가 안보입니다.
0
75
3
state 관리에 대한 정리
0
68
3
[(2.4) Shadcn/ui를 소개합니다] 강의 Shadcn 세팅 관련 질문 있습니다.
0
146
3
like 테이블에서 왜 create_at이 필요한지 궁금합니다.
0
66
1
삭제가 바로 안되네요ㅠ
0
54
2
access 토큰은 꼭 소셜서버로부터 받아서 사용해야만하나요?!
0
71
2
전역 모달이 여러 개일 경우 모달 프로바이더는 몇 개가 필요한가요?
0
52
1
프로필 수정 후 post item 의 글들에서 수정된 프로필 업데이트 반영
0
69
2

