Daniel Espino Garcia
Dos and don'ts with react hooks. An opinionated approach
#1about 4 minutes
Understanding the internal mechanics of React hooks
Hooks enable state in functional components and are implemented as a linked list, which explains why they must be called in the same order on every render.
#2about 2 minutes
Prioritize code readability over premature performance optimization
Focus on writing clear, future-proof code instead of worrying about minor performance overhead from hooks, as these are rarely the actual application bottleneck.
#3about 2 minutes
Move constants and pure functions outside components
Improve readability and performance by defining constants and pure helper functions outside the component scope, avoiding unnecessary re-creation on each render.
#4about 2 minutes
Declare explicit dependencies instead of inferring them
Always declare direct dependencies in hooks like useEffect and useCallback to prevent subtle bugs when the code is modified later.
#5about 2 minutes
Improve clarity with intermediate variables for derived state
Create meaningful intermediate variables from props or state to represent business logic, making the code more readable and hook dependencies more precise.
#6about 2 minutes
Use useRef for data that shouldn't trigger re-renders
Store values that persist across renders but don't affect the UI, like pagination counters, in a useRef to avoid unnecessary component re-renders.
#7about 1 minute
Stabilize callbacks with the functional setState form
Use the functional update form of setState to compute new state from the previous state, which removes the state variable from dependency arrays and prevents unnecessary re-creations of callbacks.
#8about 1 minute
Calculate derived state directly instead of in useEffect
If a piece of state is calculated from props within a useEffect, it is derived state and should be computed directly during the render to avoid an extra re-render cycle.
#9about 2 minutes
Extract reusable logic into custom hooks
Encapsulate and share repeated component logic, such as handling an Android back button, by creating custom hooks for better maintainability and readability.
Related jobs
Jobs that call for the skills explored in this talk.
Matching moments
01:39 MIN
Writing functional JavaScript with React components
A Guide To Functional Programming
03:44 MIN
How hooks enable superior code reusability
State management in a world of hooks
01:23 MIN
Conclusion: Benefits of using React's built-in tools
Rethinking React State Management: The Power of Built-In Solutions
02:38 MIN
The challenge of managing local versus global state
State management in a world of hooks
03:03 MIN
Lessons on testing, hooks, and framework lock-in
Building a large, complex product from the ground up with typescript & Atomic Design:lessons learned
01:54 MIN
Managing async state with React 19 hooks
Building Interactive Async UI with React 19 and Ariakit
05:41 MIN
Understanding React fundamentals for the examples
How to become an AI toolsmith
04:19 MIN
Answering questions on reactivity and browser support
Under The Hood of Vue 3 Reactivity
Featured Partners
Related Videos
Rethinking React State Management: The Power of Built-In Solutions
Marc Brehmer
State management in a world of hooks
Adam Klein
Bringing back reactivity in "reactive" frontend
Michał Moroz
MVI: Minimum Viable Interface for React Components
Daniel Espino Garcia
What the heck do "declarative" and "reactive" actually mean?
André Kovac
Common Mistakes in Vue.js and How to Avoid Them
Daniel Kelly
A Guide To Functional Programming
Jemima Abu
Building Interactive Async UI with React 19 and Ariakit
Aurora Scharff
Related Articles
View all articles



From learning to earning
Jobs that call for the skills explored in this talk.

Nia Health GmbH
Berlin, Germany
Intermediate
Senior
CSS
GIT
React
TypeScript

Schulz.codes GmbH
Darmstadt, Germany
Intermediate
Senior
React
JavaScript
TypeScript

doinstruct Software GmbH
Berlin, Germany
Senior
GIT
JavaScript
TypeScript

BSB Bremer Software & Beratungs GmbH
Bremen, Germany
Intermediate
Senior
CSS
Java
HTML
React
JavaScript
+1



Smartclip
Berlin, Germany
Remote
Intermediate
Figma
Node.js
GraphQL
TypeScript

K LAGAN
Málaga, Spain
