Inflearn Community Q&A
댓글 삭제 시 isPending 질문
Written on
·
23
0
const { mutate: deleteComment, isPending: isDeleteCommentPending } =
useDeleteComment({
onError: (error) =>
toast.error("댓글 삭제에 실패했습니다", { position: "top-center" }),
});여기서 isPending을 쓸만한 곳이 없는거 같은데 굳이 필요한 이유가 있을까요?
Answer 2
0
안녕하세요 gmldnjs0402님 이정환입니다.
넵 해당 컴포넌트에서는 지금 당장 isPending을 사용할 필요는 없습니다.
그러나 나중에 사용자 경험을 개선하고 싶을 때 유용하게 활용할 수 있습니다. 예를 들어 isPending이 true인 동안 버튼을 비활성화하거나, 로딩 스피너를 보여주는 등의 처리를 할 수 있거든요.
강의에서 isPending을 함께 구조분해할당한 이유는, useTransition이 반환하는 값의 구조를 보여드리기 위함이었습니다. 실제로 사용하지 않더라도 "이런 값이 함께 제공된다"는 걸 알아두시면 나중에 필요할 때 바로 활용하실 수 있으니까요!
그러니 지금은 isPending을 사용하지 않더라도 전혀 문제없고, 필요한 시점이 오면 그때 활용하시면 됩니다 😀
0
안녕하세요, 인프런 AI 인턴입니다. gmldnjs0402님.
isPending은 비동기 작업의 진행 상태를 나타내는 데 유용한 상태로, 사용자가 작업을 요청했을 때 해당 작업이 진행 중인지 여부를 알릴 수 있습니다.
isPending의 사용 용도
사용자 피드백: 댓글 삭제 요청이 서버로 전송되고 처리될 때까지 어느 정도 시간이 소요될 수 있습니다. 이 동안
isPending을 사용하면 사용자가 삭제가 진행 중임을 명확하게 알 수 있도록 UI에 로딩 스피너나 진행 메시지를 표시할 수 있습니다.버튼 비활성화: 요청이 진행 중일 때 같은 작업이 중복으로 시작되지 않도록, 예를 들어 댓글 삭제 버튼을 누적 클릭 방지 목적에서 비활성화할 수도 있습니다.
isPending을 화면 상태에 활용하면 사용자가 동일한 요청을 반복해서 보내지 않도록 할 수 있습니다.
React Query에서 isPending 상태는 이처럼 비동기 작업의 중간 상태를 나타내기 때문에 인터페이스에서 비동기 작업이 충분히 주의 깊게 처리되고 있음을 사용자에게 전달할 수 있도록 하는 데 중요한 역할을 합니다.
유사한 질문이나 React Query 사용에 관련된 추가적인 내용을 알아보고 싶으시다면, 아래의 게시물들을 참고하세요:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.




