대규모 React 애플리케이션에서는 불필요한 재렌더링이 심각한 문제가 되어 성능이 저하되고 앱이 느리게 느껴질 수 있습니다. React 18을 사용하면 자동 일괄 처리를 통해 불필요한 재렌더링을 줄여 성능을 최적화하고 개발자에게 상태 업데이트를 보다 효율적으로 관리할 수 있는 방법을 제공합니다. 이 가이드는 React 18의 자동 일괄 처리 개념, 이것이 성능에 중요한 이유, 앱에서 이를 최대한 활용하는 방법을 안내합니다.
저녁 요리를 하고 있는데 모든 요리를 한 번에 만드는 대신 계속 왔다 갔다 하면서 각각 따로 만든다고 가정해 보세요. 확실히 효율적이지 않죠? 상태 업데이트가 하나씩 처리될 때 React에서도 동일한 일이 발생하여 단 하나가 아닌 여러 렌더링이 발생합니다. 이는 특히 대규모 애플리케이션에서 처리 낭비와 성능 저하로 이어집니다.
React 18 이전에는 서로 가깝게 발생하는 상태 업데이트로 인해 여러 번 다시 렌더링되는 경우가 많았습니다. React 18은 여러 업데이트를 단일 렌더링 주기로 그룹화하는 자동 일괄 처리로 이 문제를 해결하여 불필요한 재렌더링을 줄이고 성능을 향상시킵니다.
자동 일괄 처리는 React 18에 도입된 기능으로, React가 동일한 이벤트 또는 효과 내에서 여러 상태 업데이트를 처리한 다음 단 한 번의 재렌더링을 트리거할 수 있습니다. 이렇게 하면 렌더링 횟수가 최소화되고 애플리케이션의 전반적인 성능이 향상됩니다.
React 18 이전에는 일괄 처리가 이벤트 핸들러 내부에서만 적용되었습니다. 그러나 React 18은 일괄 처리를 setTimeout, promise 및 이벤트 리스너와 같은 비동기 함수 내의 모든 업데이트로 확장하여 더욱 강력하고 포괄적으로 만듭니다.
다음은 React 18에서 자동 일괄 처리가 작동하는 방식에 대한 예입니다.
import { useState } from 'react'; function MyComponent() { const [count, setCount] = useState(0); const [text, setText] = useState(''); function handleClick() { setCount(count 1); setText('Updated'); // Both updates are batched, and only one re-render happens } return (); }{count}
{text}
위 코드에서 개수와 텍스트에 대한 상태 업데이트는 함께 일괄 처리되어 두 개가 아닌 단일 재렌더링을 트리거합니다. 이는 React 18의 자동 일괄 처리 덕분입니다.
React에서는 상태가 변경될 때마다 다시 렌더링이 발생합니다. 이벤트 핸들러처럼 여러 상태 업데이트가 차례로 발생하는 경우 React는 일반적으로 여러 렌더링을 트리거합니다. 이로 인해 특히 확장 시 앱 속도가 느려질 수 있습니다.
자동 일괄 처리는 이러한 상태 업데이트를 단일 렌더 패스로 결합합니다. 여러 필드가 포함된 양식을 작성하고 각 입력 변경으로 인해 전체 양식이 다시 렌더링된다고 상상해 보세요. 자동 일괄 처리를 통해 React는 모든 변경 사항을 한 번에 처리하므로 UI가 더 부드럽고 빠르게 느껴집니다.
자동 일괄 처리는 다음을 포함한 다양한 상황에서 작동합니다.
function handleSubmit() { setFormSubmitted(true); setFormData({ ...formData, submittedAt: new Date() }); // Only one re-render happens here }
setTimeout(() => { setLoading(false); setUser({ name: 'John' }); // These state changes are batched, so only one re-render }, 1000);
즉, 비동기 작업에서도 React는 여러 업데이트를 그룹화하여 성능을 향상하고 재렌더링 횟수를 최소화할 수 있습니다.
상태 업데이트가 발생하는 시기를 수동으로 제어해야 하는 경우가 있을 수 있습니다. 특히 애니메이션이나 중요한 UI 업데이트 작업을 할 때 더욱 그렇습니다. 여기가 flushSync가 필요한 곳입니다. 이는 React가 다른 업데이트와 함께 일괄 처리하는 대신 즉시 업데이트를 처리하도록 합니다.
React가 일괄 업데이트를 기다리지 않고 상태가 즉시 업데이트되어 DOM에 반영되는지 확인해야 하는 시나리오에서는 flashSync를 사용해야 합니다. 이는 애니메이션이나 즉각적인 시각적 피드백과 같이 타이밍이 중요한 상황에서 종종 필요합니다.
flushSync의 작동 방식은 다음과 같습니다.
import { flushSync } from 'react-dom'; function handleClick() { flushSync(() => { setCount(count 1); }); // The DOM is updated immediately after the state change console.log('Count updated:', count); }
이 예에서 React는 setCount 업데이트를 즉시 처리하여 DOM이 변경 사항을 즉시 반영하도록 하며 이는 시간에 민감한 작업에 유용합니다.
React 18의 자동 일괄 처리는 불필요한 재렌더링을 줄여 성능을 최적화하고 애플리케이션을 더 빠르고 원활하게 실행하는 획기적인 기능입니다. 상태 업데이트를 단일 렌더링으로 그룹화함으로써 React는 앱의 UI가 확장되더라도 반응성과 효율성을 유지하도록 보장합니다.
대부분의 사용 사례에서 자동 일괄 처리는 기본적으로 완벽하게 작동하지만 더 많은 제어가 필요한 경우 flushSync를 사용하여 실시간으로 업데이트를 처리할 수 있습니다.
이러한 기능을 활용함으로써 개발자는 이제 불필요한 렌더링을 최소화하고 React 앱의 전반적인 성능을 향상시켜 더 나은 사용자 경험을 보장할 수 있습니다.
자동 일괄 처리로 React 앱을 최적화할 준비가 되셨나요? 다음 프로젝트에서 이 기능을 구현해 보고 앱 성능이 얼마나 향상되는지 확인해 보세요!
이 기사가 마음에 드셨다면 제 작업을 후원해 보세요.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3