> 웹 프론트엔드 > JS 튜토리얼 > 'setTimeout' 호출 후 내 React 상태가 즉시 업데이트되지 않는 이유는 무엇입니까?

'setTimeout' 호출 후 내 React 상태가 즉시 업데이트되지 않는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-17 14:32:12
원래의
795명이 탐색했습니다.

Why Isn't My React State Updating Immediately After a `setTimeout` Call?

React에서 상태가 업데이트되지 않음: setTimeout 미스터리 탐구

React의 setState() 메서드는 업데이트와 관련하여 종종 혼동의 대상이 됩니다. 즉시 상태를 확인하세요. 이 특정 사례에서 개발자는 상태가 예상대로 업데이트되지 않는 시나리오에 직면하게 됩니다.

개발자는 숫자 배열인 newDealersDeckTotal을 가지고 있으며, 이는 감소()를 사용하여 총계로 누적됩니다. 그런 다음 setTimeout 함수 내에서 DealsOverallTotal 상태를 이 합계로 설정합니다. 그러나 setTimeout 전후에 상태 값을 기록하면 잘못된 결과가 생성됩니다.

이 동작을 이해하는 열쇠는 setState()의 비동기 특성에 있습니다. 상태가 즉시 설정되어야 하는 것처럼 보일 수 있지만 이 메서드는 비동기식입니다. 즉, 즉시 반영되지 않을 수 있는 상태 업데이트를 예약한다는 의미입니다. 이것이 setTimeout 함수 전후의 상태를 콘솔에 로깅하면 결과가 다른 이유입니다.

이 문제를 해결하려면 개발자는 상태 업데이트가 완료된 후 실행되는 setState()의 콜백 함수를 활용할 수 있습니다. 개발자는 이 콜백 내에 콘솔 로그 문을 배치하여 로그가 실행되기 전에 상태가 업데이트되도록 보장합니다. 수정된 코드는 다음과 같습니다.

this.setState({ dealersOverallTotal: total }, () => {
  console.log(this.state.dealersOverallTotal, 'dealersOverallTotal1');
});
로그인 후 복사

이 솔루션을 사용하면 콘솔 로그가 실행될 때 상태가 정확하게 반영되어 예상한 결과를 제공합니다. React setState() 메서드의 비동기 동작을 이해하면 개발자가 유사한 상태 업데이트 함정을 피하는 데 도움이 될 수 있습니다.

위 내용은 'setTimeout' 호출 후 내 React 상태가 즉시 업데이트되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿