- FrontendJoy
- Posts
- 5 Small (Yet Easily Fixable) Mistakes Junior Frontend Developers Often Make in Their React Code
5 Small (Yet Easily Fixable) Mistakes Junior Frontend Developers Often Make in Their React Code
data:image/s3,"s3://crabby-images/1269e/1269e8c3b4d56701e9d1be3572c3d7b5c3ce4414" alt=""
I have reviewed more than 1,000 frontend pull requests.
Like many junior developers, I made some common React mistakes when I started.
If you're in the same boat, here are 5 small ones you can quickly fix to keep your code clean and performant:
Mistake #1: Creating a state that can be derived from props + existing state
If you can calculate a value from existing props, please do so. Creating a state for it adds complexity and raises the risk of state discrepancies (some updated, others not).
data:image/s3,"s3://crabby-images/33ef1/33ef14cb88a916845d0b5d9e6210652101d66212" alt=""
Mistake #2: Using items.length && <MyComponent />
Let's say you only want to render a component when a list is non-empty. So you use items.length && <MyComponent />
. The problem is that this code will print 0
on the screen when the list is empty. Instead, use items.length > 0 && <MyComponent />
.
data:image/s3,"s3://crabby-images/1f47c/1f47c2163a447b96fa5d77e974d8fb096c181f28" alt=""
Mistake #3: Using useEffect
unnecessarily or dangerously
Be cautious with the dependencies list in useEffect
; if poorly set, it might crash your app or lead to inconsistent UI. Additionally, try to minimize its use for better performance and code readability.
data:image/s3,"s3://crabby-images/cc23c/cc23c05a095de035963ff06b968bcfb7fdd5e4a6" alt=""
Mistake #4: Having multiple setState vs. combining into a single state or using reducer
If you have more than 3-5 pieces of state that are strongly correlated, avoid multiple setState
. Instead, opt for a single setState or use useReducer
to maintain cleaner code.
data:image/s3,"s3://crabby-images/91c5f/91c5fe8c50173770465659cb48f14a61a8f29d1c" alt=""
Mistake #5: Accidentally breaking the component memoization
A common mistake, especially for beginners, is breaking the memoization created by React.memo
. Make sure you don't accidentally pass objects or arrow functions, as it renders memoization ineffective.
data:image/s3,"s3://crabby-images/4d09e/4d09e4fe8bca9170581fb6b8ac713b7dc2e666bc" alt=""
Reply