inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

2번 클릭해야 axios.delete 반응하는 이유

288

minsu

작성한 질문수 27

0

안녕하세요 제로초님 제가 출력 된 것들을 삭제 하는 함수를 만들고 있습니다.
제가 category 값을 map 함수로 출력 해 준 뒤
li value값에 category id 값을 넣어 주었습니다.
 
값을 제어 할려고 -> useState(categoryId) 만들어 주었습니다.
li 태그 onClick 를 하면 ContentDelete 라는 삭제하는 함수가 호출 됩니다.
 
그리고 e.target.value 을 이용해서 -> categoryId 에 value 값을 넣어주었습니다.
그리고 categoryId 값을 서버에 호출 해 주었습니다.
 
하지만 Delete li 태그 onClick 를 2번 해야 axios.delete 가 먹힙니다.
 
DELETE http://localhost:3065/api/category/0 404 (Not Found) -> 한 번 클릭 할 경우 useState 초기값인 0이 나옵니다.
DELETE http://localhost:3065/api/category/18 404 (Not Found) -> 한 번 더 클릭해야 18이 나오고 404 에러가 나지만 삭제는 됩니다.
 
왜 이러는 지 모르겠습니다... async await 으로 비동기 처리도 제대로 해 주고 return 문에다가 넣어주었는데 왜 처음 클릭하면 state 초기값인 0이 찍히는 지...
 
const [categoryId, setCategoryId] = useState<number>(0);
 
const ContentDelete = useCallback( async (e) => {
setCategoryId(e.target.value);
return await axios.delete(`http://localhost:3065/api/category/${categoryId}`, {
withCredentials: true,
})
}, [categoryId])
 
return (
<ul>
{categorys && categorys.map((test: { id: any, content: React.ReactChild }) => (
<li key={test.id} value={test.id} onClick={ContentDelete}>{test.content}
<AiOutlineClose />
</li>
))}
</ul>
)

babel 웹팩 Socket.io typescript react 클론코딩

답변 1

1

제로초(조현영)

setCategoryId는 비동기라서 categoryId에 값이 적용되기 전에 axios가 더 먼저 실행됩니다.

axios는 useEffect 내부에서 categoryId의 변화를 감지한 후에 실행하셔야 합니다.

0

제로초(조현영)

아니면 axios에 e.target.value를 하시면 되겠네요.

기본 셋팅과 관련하여

0

106

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

109

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

165

2

useEffect 개수 관리

0

122

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

80

1

npm run dev 에러

0

156

3

npx webpack 후 에러

0

187

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

151

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

192

2

초기세팅중 packge.json 에러떠요

0

162

2

CORS - Access-Control-Allow-Origin 누락 문제

0

439

3

로그인 페이지 무한 새로고침 현상

0

608

2

Module not found: Error: Can't resolve './App' 에러

0

970

1

배포 방법

0

306

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1010

2

alias 경로 설정 오류

0

461

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

377

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

395

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

341

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

252

2