작성
·
362
·
수정됨
0
import React,{useState} from 'react';
function Exptest (){
const [number, setNumber] = useState('A');
const checkNumber =() =>{
alert("첫번째 "+number);
setNumber(function (prevnumber){
alert(prevnumber+"/3번/"+number);
setNumber((prevnumber)=>{
alert(prevnumber+"/4번/"+number);
return prevnumber+'B';
});
return prevnumber+'C';
});
alert("두번째"+number);
};
return (
<>
<button onClick = {checkNumber}> {number} </button>
</>
);
};
export default Exptest;
/*
이런식으로 안쓰는건 알지만 실행순서에 대해서 공부하다 이것저것 해보다가 이해가 안가서 질문드립니다.
질문1.
처음 버튼 클릭 시 number='A' -> number = 'AC' 이렇게 업데이트된다.
그리고 두번 째 실행 시 결과는 number = 'ACCB' 가 되는데 왜 처음엔 B를 추가하지 않나요?
질문2.
alert 메세지가 뜨는 순서를 보면 처음 버튼 클릭 시
첫번째 A -> A/3번/A -> A/4번/A -> 두번째 A
그리고 두번 째 버튼 클릭 부터는
첫번째 AC -> 두번째 AC -> AC/3번/AC -> ACC/4번/AC
이렇게 메세지가 뜨는데 왜 순서가 달라지나요?
*/
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
님의 질문에 관한 답변은 다음과 같습니다.
질문1에 대한 답변:
React의 useState
와 관련된 업데이트는 비동기적으로 실행됩니다. 초기 클릭 시 setNumber
를 체이닝하여 호출하게 되면, React는 성능 최적화를 위해 여러 상태 업데이트를 배치(Batch) 처리합니다. 첫 번째 클릭에서 ‘B’를 추가하지 않는 이유는, 첫 번째 setNumber
호출에서 반환한 값(‘AC’)만이 다음 상태 업데이트에 반영되고, 내부 setNumber
호출은 다음 렌더링 사이클에서 처리되기 때문입니다. 그래서 ‘B’가 바로 추가되지 않고, 두 번째 클릭 시점에서 ‘B’가 추가됩니다.
질문2에 대한 답변:
첫 번째 버튼 클릭 시 뜨는 메시지 순서는 React가 상태 업데이트를 배치 처리하는 방식 때문에, 상태 업데이트(setNumber
)가 즉시 반영되지 않습니다. 이로 인해 alert
가 호출될 때 number
상태는 아직 업데이트되지 않은 상태를 참조합니다. 다른 편, 두 번째 버튼 클릭부터는 첫 번째 setNumber
호출이 배치 처리되어 업데이트되고, 이후 alert
가 실행될 때는 업데이트된 상태를 참조할 수 있게 되므로, number
상태가 변경된 후의 값을 보여주게 됩니다. 이러한 차이로 인해 메시지가 뜨는 순서가 달라집니다.
React의 상태 업데이트 메커니즘과 비동기 처리 로직의 이해를 돕기 위해서는, 공식 문서에서 제공하는 훅 관련 문서와 자바스크립트의 비동기 처리 방식에 대해 추가적으로 공부하는 것이 좋습니다.