技術問答
技術文章
iT 徵才
Tag
聊天室
2024 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2023 iThome 鐵人賽
0
Modern Web
前端知識
系列 第
29
篇
10 React Antipatterns to Avoid - Code This, Not That!
15th鐵人賽
jasonchenchen
2023-10-29 16:55:49
349 瀏覽
分享至
React Anti-patterns and Solutions
Anti-pattern 1: Big Components
Problem
: Starting off with one big, deeply nested component.
Solution
: Refactor into smaller, reusable components.
Anti-pattern 2: Nesting Components
Problem
: Defining child components inside parent components.
Solution
: Define child components outside the parent component.
Anti-pattern 3: Failure to Memoize
Problem
: Running expensive calculations every time the state changes.
Solution
: Use the `useMemo` hook.
Anti-pattern 4: Useless Divs
Problem
: Wrapping multiple elements in unnecessary `div` tags.
Solution
: Use React Fragments.
Anti-pattern 5: Messy Files
Problem
: Exporting multiple components from a single file.
Solution
: One component per file.
Anti-pattern 6: Big Bundles
Problem
: Slow initial page load due to large JavaScript bundles.
Solution
: Use code splitting and lazy loading.
Anti-pattern 7: Prop Drilling
Problem
: Passing state through multiple layers of components.
Solution
: Use context API for global state management.
Anti-pattern 8: Prop Plowing
Problem
: Components with a lot of different props.
Solution
: Use the spread syntax.
Anti-pattern 9: Messy Event Handlers
Problem
: Using arrow functions for event handlers with multiple arguments.
Solution
: Use curried functions.
Anti-pattern 10: Single Object State
Problem
: Using a single object for all state in a component.
Solution
: Use multiple `useState` hooks, and extract to custom hooks
留言
追蹤
檢舉
上一篇
Better optimistic update
下一篇
ts-reset
系列文
前端知識
共
30
篇
目錄
RSS系列文
訂閱系列文
2
人訂閱
26
Learn React Hooks: useRef - Simply Explained!
27
Next.js 14.0 ( server action )
28
Better optimistic update
29
10 React Antipatterns to Avoid - Code This, Not That!
30
ts-reset
完整目錄
直播研討會
{{ item.subject }}
{{ item.channelVendor }}
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
206
組
團體組數
4
組
累計文章數
499
篇
最後報名日
9/15
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
13th鐵人賽
14th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
2018鐵人賽
javascript
2017鐵人賽
python
windows
php
c#
windows server
linux
css
react
程式設計
vue.js
熱門問題
程式超級小白想學Python
因為公司資安政策問題,不能直接開限制IP的遠端管理者設備的管理介面,但是可以使用 anydesk teamviewer連線
網域使用者帳號清查 - Script
我在學習javascript,本人高三剛畢業技術不好請見諒,可以幫我看看我寫的notion筆記有錯誤嗎?(我把筆記publish了)
【閒聊】請問台灣彩券技術是否會造假
請問有 AI 工具或是特別方式能將 ChatGPT 變成口語化嗎?
網域使用者帳號清查
LB路由配置問題
Fortigate 50E*2 Lab的SD WAN、VPN 、vdom、政策路由、...等問題請教
VPN連線健保網路的問題
熱門回答
【閒聊】請問台灣彩券技術是否會造假
程式超級小白想學Python
FortiGate兩層式防火牆及多VLAN
FortiClient VPN一直卡在連線中狀況(無連線進度條)
LB路由配置問題
熱門文章
2024 Day01 緣起
2024 Day03 軟體測試的簡介
2024 Day02 品質是什麼
D同事 的專案簡報 Review
1-5 撰寫Prompt與System Instructions的五個基本原則
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}