> 웹 프론트엔드 > JS 튜토리얼 > React에서 useState를 사용할 때 가장 흔히 저지르는 실수

React에서 useState를 사용할 때 가장 흔히 저지르는 실수

Mary-Kate Olsen
풀어 주다: 2024-10-02 06:20:01
원래의
272명이 탐색했습니다.

The ost Common Mistakes When Using useState in React

React 프로젝트에서 useState는 기능 구성 요소의 상태를 관리하기 위해 가장 일반적으로 사용되는 후크 중 하나입니다. 그러나 개발자가 이 후크를 사용할 때 저지르는 몇 가지 일반적인 실수가 있으며, 이로 인해 성능 문제와 예상치 못한 버그가 발생할 수 있습니다. 이번 글에서는 useState를 사용할 때 저지르는 가장 일반적인 4가지 실수를 살펴보고 이를 방지하는 방법에 대한 팁을 제공하겠습니다.

1. useState를 초기화하는 함수를 사용하지 않음

useState로 상태를 초기화할 때 초기 상태가 비용이 많이 드는 함수의 결과인 경우 이 함수는 렌더링할 때마다 호출됩니다. 특히 함수에 복잡한 계산이 포함된 경우 성능에 심각한 영향을 미칠 수 있습니다.

잘못된 사용법:

const [data, setData] = useState(expensiveFunction());
로그인 후 복사

이 예에서는 expensiveFunction이 렌더링할 때마다 호출되어 불필요한 성능 비용이 발생합니다.

올바른 사용법:

const [data, setData] = useState(() => expensiveFunction());
로그인 후 복사

useState 내부의 함수를 사용하면 값비싼 함수가 초기 렌더링 중에만 호출되어 후속 렌더링에서 리소스를 절약할 수 있습니다.

2. setState 함수의 오용

React에서 상태를 업데이트할 때, 특히 새 상태가 이전 상태에 따라 달라지는 경우 setState의 기능적 형식을 사용하는 것이 중요합니다. 일반적인 실수는 이전 값을 고려하지 않고 상태를 업데이트하는 것입니다.

잘못된 사용법:

setCount(count + 1);
로그인 후 복사

여러 업데이트가 빠르게 연속해서 실행되면 문제가 발생할 수 있습니다count에 가장 최근에 업데이트된 값이 없을 수 있기 때문입니다.

올바른 사용법:

setCount(prevCount => prevCount + 1);
로그인 후 복사

이 접근 방식을 사용하면 이전 값을 기반으로 상태가 업데이트되어 더욱 안정적이게 됩니다.

3. useState의 잘못된 배치

React의 후크에는 몇 가지 엄격한 규칙이 있으며, 그 중 하나는 기능적 구성 요소의 최상위 수준에서만 사용할 수 있다는 것입니다. 루프, 조건 또는 중첩 함수 내부에 후크를 배치하면 React의 상태 관리 메커니즘

이 중단될 수 있습니다.

잘못된 사용법:

if (condition) {
  const [value, setValue] = useState(false);
}
로그인 후 복사

이것은 React의 규칙을 위반합니다useState는 조건문 안에 배치되어서는 안 되기 때문입니다

올바른 사용법:

const [value, setValue] = useState(false);

if (condition) {
  // Use the state here
}
로그인 후 복사

useState를 조건이나 루프 외부에 유지함으로써 React는 후크가 호출되는 순서를 적절하게 관리할 수 있습니다.

4. 상태 직접 변경

React의 상태는 불변으로 처리되어야 합니다. 상태를 직접 변경하면 특히 객체나 배열

을 다룰 때 예상치 못한 버그와 문제가 발생할 수 있습니다.

잘못된 사용법:

const [user, setUser] = useState({ name: 'John', age: 30 });
user.name = 'Jane';  // Incorrect mutation
setUser(user);       // Incorrect update
로그인 후 복사

React가 상태 변경을 감지하지 못하기 때문에 사용자를 직접 변경해도 다시 렌더링이 실행되지 않습니다.

올바른 사용법:

setUser(prevUser => ({
  ...prevUser,
  name: 'Jane'
}));
로그인 후 복사

여기서 확산 연산자를 사용하여 새 객체가 생성되어 상태의 불변성을 보장하고 적절한 재렌더링을 트리거합니다.

결론

useState를 사용할 때 흔히 발생하는 실수를 방지하면 React 애플리케이션의 성능과 안정성을 크게 향상시킬 수 있습니다. 상태를 적절하게 초기화하든, 기능 업데이트를 사용하든, 불변성을 보장하든 이러한 모범 사례를 염두에 두면 더 깔끔하고 효율적인 React 코드를 작성하는 데 도움이 됩니다.

위 내용은 React에서 useState를 사용할 때 가장 흔히 저지르는 실수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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