이전에 배운 State
에 대해서 기억하시나요?
State
란 리액트 컴포넌트에서 데이터를 담기 위한 상자라고 했었습니다. 이 상자에 담긴 내용들은 함수가 모두 끝나게 되면 화면에 반영이 되는데요. State
를 이해하기 위해 만든 counter
를 다시 보겠습니다.
import { useState } from 'react'
function New() {
const [count, setCount] = useState(0)
function handleClick() {
setCount(count + 1) // 갯수가 증가하면서, 화면에 정상적으로 **반영됨**
}
return (
<div>
<h1>{count}</h1>
<button onClick={handleClick}>state를 사용하여 count 증가</button>
</div>
)
}
export default New
위 코드를 화면에 출력해보면 버튼을 클릭할 때 마다 갯수가 하나씩 증가하면서 정상적으로 반영됩니다.
하지만, count를 5개씩 증가시켜주기 위해 코드가 아래와 같이 바뀌게 된다면 어떻게 될까요? 우리가 의도한대로 count가 5개씩 증가될까요?
function handleClick() {
setCount(count + 1) // 현재 count는 0 + 1 => 1을 상자에 담는다.
setCount(count + 1) // 1 이 상자에 담겼지만 여전히 count는 0 이므로 1이 상자에 담긴다
setCount(count + 1) // ...
setCount(count + 1) // ...
setCount(count + 1) // 같은 방식으로 최종적으로 1이 상자에 담겨 화면에 1이 반영된다
}
위와 같은 로직에 따라 count가 하나씩만 증가되게 됩니다. 우리가 의도한대로 count가 5개씩 증가되도록 하려면 prev
라는 임시저장공간을 사용하여 작성해야합니다.
function handleClick() {
setCount((prev)=>prev+1) // 임시저장공간의 0(기본값, prev) + 1 => 1을 상자에 담는다.
setCount((prev)=>prev+1) // 임시저장공간에 담긴 1(prev) + 1 => 2를 상자에 담는다.
setCount((prev)=>prev+1) // ...
setCount((prev)=>prev+1) // ...
setCount((prev)=>prev+1) // 같은 방식으로 최종적으로 5가 상자에 담겨 화면에 5가 반영된다
}
이렇게 prev
를 사용하시게되면 임시 저장공간에 있는 값을 먼저 꺼내오고, 만약 임시 저장공간에 있는 값이 없다면 기본 값을 불러오게 됩니다.
prev
를 사용하시게되면 우리가 의도한대로 화면에 반영함과 동시에, 코드를 리팩토링하는데도 효율적이기 때문에 잘 활용해주시면 좋겠습니다.
위 코드만 봐서는 4씩 증가할 거 같습니다.
하지만 실제로 실행되는거 보면 1씩만 증가하고 있습니다…
state는 함수가 끝나면 값이 적용되는 특성이 있습니다.
그래서 setState를 4번이나 적었다고 4씩 늘어나는게 아니고 같은 함수 안에 들어있다면 증가하지 않고 그대로 초깃값에 1을 더하는 샘입니다.
const [ count, setCount] = useState(0) const OnClickCount = () => { setCount((prev)=>(prev+1)) setCount((prev)=>(prev+1)) setCount((prev)=>(prev+1)) setCount((prev)=>(prev+1)) }
이렇게 작성하면 임시 저장공간을 확인하게 됩니다.
임시 저장공간에 아무것도 없을 경우에는 기본 초깃값을 가지고 와서 사용합니다.
첫 줄에서 초깃값을 사용해 1을 증가 시키고 임시 저장공간에 저장시킵니다.
둘째 줄에서는 임시 저장공간에서 값이 있는지 확인했더니 1이라는 숫자가 존재합니다. 그래서 그 1에 1을 더해 2을 만들어 임시 저장 공간에 넣습니다.
세번째 줄, 네번째 줄도 두번째 줄과 동일하게 임시 저장공간 숫자를 증가시킵니다.
그래서 최종 4가 되는 것입니다.