>웹 프론트엔드 >JS 튜토리얼 >React의 `setState`가 상태를 즉시 업데이트하지 않는 이유는 무엇입니까?

React의 `setState`가 상태를 즉시 업데이트하지 않는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-24 20:47:12598검색

Why Doesn't React's `setState` Update the State Immediately?

React의 setState 메소드의 비동기적 특성 이해

React에서 setState 메소드는 구성 요소의 상태를 업데이트하는 데 중요한 역할을 합니다. 그러나 setState가 구성 요소의 상태를 즉시 변경하지 않는다는 점에 유의하는 것이 중요합니다. 대신 상태 업데이트를 예약하고 실제 업데이트는 비동기적으로 발생합니다.

이 setState의 비동기 동작은 React 문서에 설명되어 있습니다.

setState() does not immediately mutate this.state but creates a pending state transition. Accessing this.state after calling this method can potentially return the existing value. There is no guarantee of synchronous operation of calls to setState and calls may be batched for performance gains.

따라서 구성 요소 내에서 setState가 호출되면 콜백(예: 제공된 코드의 handlerChange), 업데이트된 상태는 해당 콜백 범위 내에서 즉시 사용할 수 없습니다. 이것이 handlerChange 콜백 내부의 두 번째 console.log가 this.state.value의 원래 값을 인쇄하는 이유입니다.

상태 변경이 발생한 후 함수가 실행되도록 하려면 콜백으로 전달해야 합니다. setState:

this.setState({value: event.target.value}, function () {
    console.log(this.state.value);
});

이 접근 방식을 사용하면 제공된 콜백 함수는 상태가 업데이트된 후에만 실행되어 올바른 값이 콘솔.

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.