DEV Community

Cover image for 10 React Mistakes You Must Avoid as a Developer πŸš€
 Precious Kelvin Nwaogu
Precious Kelvin Nwaogu

Posted on

14 1 2 1 3

10 React Mistakes You Must Avoid as a Developer πŸš€

React is powerful, but even experienced developers fall into common traps that can slow performance and make debugging a nightmare. Let’s explore ten mistakes you should avoid at all costs!

1️⃣ Modifying State Directly
Changing state directly instead of using setState or state setters in hooks can cause unexpected behavior. Always treat state as immutable.

❌ Bad:

state.count = state.count + 1; // Wrong ❌
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

setState(prev => ({ count: prev.count + 1 })); // Correct βœ…
Enter fullscreen mode Exit fullscreen mode

2️⃣ Not Using Keys in Lists
React uses keys to track elements efficiently. Skipping keys in .map() can lead to rendering issues.

❌ Bad:

items.map(item => <li>{item.name}</li>); // No key ❌
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

items.map(item => <li key={item.id}>{item.name}</li>); // Correct βœ…
Enter fullscreen mode Exit fullscreen mode

3️⃣ Excessive Re-renders
Unnecessary renders can hurt performance. Use useMemo, useCallback, and React.memo when needed.

4️⃣ Not Cleaning Up Effects
Forgetting cleanup in useEffect can cause memory leaks, especially in event listeners and timers.

βœ… Always cleanup:

useEffect(() => {
  const interval = setInterval(() => {
    console.log('Running...');
  }, 1000);

  return () => clearInterval(interval); // Cleanup βœ…
}, []);
Enter fullscreen mode Exit fullscreen mode

5️⃣ Using useEffect Unnecessarily
Sometimes, useEffect is overused for things that can be done without it, like directly setting state in event handlers.


6️⃣ Ignoring Dependency Arrays in useEffect
Incorrect dependency arrays can cause infinite loops or missing updates.

❌ Bad:

useEffect(() => {
  fetchData();
}); // No dependency array ❌
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

useEffect(() => {
  fetchData();
}, [dependency]); // Correct βœ…
Enter fullscreen mode Exit fullscreen mode

7️⃣ Using State When a Ref is Better
State updates cause re-renders, but refs don’t. If you don’t need reactivity, use useRef.

❌ Bad:

const [count, setCount] = useState(0); // Re-renders on update ❌
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

const countRef = useRef(0); // No re-render βœ…
Enter fullscreen mode Exit fullscreen mode

8️⃣ Not Handling Asynchronous State Updates
React batches updates, so relying on outdated state can cause bugs.

❌ Bad:

setCount(count + 1); // Might not update correctly ❌
setCount(count + 1); 
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

setCount(prev => prev + 1); // Always correct βœ…
setCount(prev => prev + 1);
Enter fullscreen mode Exit fullscreen mode

9️⃣ Blocking the UI with Expensive Computations
Heavy calculations in render can slow down the UI. Use useMemo.

❌ Bad:

const result = expensiveCalculation(data); // Runs on every render ❌
Enter fullscreen mode Exit fullscreen mode

βœ… Good:

const result = useMemo(() => expensiveCalculation(data), [data]); // Optimized βœ…
Enter fullscreen mode Exit fullscreen mode

πŸ”Ÿ Not Handling Errors Properly
Without error boundaries, one crash can break the whole app.

βœ… Always use an error boundary:

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  static getDerivedStateFromError() {
    return { hasError: true };
  }

  render() {
    if (this.state.hasError) {
      return <h2>Something went wrong.</h2>;
    }
    return this.props.children;
  }
}
Enter fullscreen mode Exit fullscreen mode

Wrap components like this:

<ErrorBoundary>
  <MyComponent /> // component name
</ErrorBoundary>
Enter fullscreen mode Exit fullscreen mode

πŸ’‘ Did you find these helpful? What other React mistakes have you seen? Share in the comments! πŸ‘‡

πŸ’‘ Want more React tips? Follow me for weekly posts on writing better React code!

SurveyJS custom survey software

JavaScript UI Libraries for Surveys and Forms

SurveyJS lets you build a JSON-based form management system that integrates with any backend, giving you full control over your data and no user limits. Includes support for custom question types, skip logic, integrated CCS editor, PDF export, real-time analytics & more.

Learn more

Top comments (3)

Collapse
 
allukyy profile image
ricki friadi β€’

thanks, it's so helpful

Collapse
 
uttam_py profile image
Uttam Sharma β€’

Thanks, it's helpful

Collapse
 
juniourrau profile image
Ravin Rau β€’

nicely written. It will be helpful for beginners.

Image of Docusign

πŸ› οΈ Bring your solution into Docusign. Reach over 1.6M customers.

Docusign is now extensible. Overcome challenges with disconnected products and inaccessible data by bringing your solutions into Docusign and publishing to 1.6M customers in the App Center.

Learn more