React important tropics
নিচে React-এর উল্লেখ করা প্রতিটি টপিক বাংলায় বিস্তারিতভাবে ব্যাখ্যা করে কোড উদাহরণসহ দিলাম। আমি চেষ্টা করেছি বাস্তবজীবনের রিয়েল-ওয়ার্কফ্লো এবং পারফরম্যান্স-প্যাটার্নগুলোও দিক।
1) Hook কিভাবে (কখন/কেন) ব্যবহার করে — Custom Hook কেমন বানাবেন
Hook মূলত function component-এ state ও lifecycle logic ব্যবহার করার উপায়। প্রধান built-in hooks: useState, useEffect, useRef, useMemo, useCallback, useReducer ইত্যাদি।
কখন/কেন:
-
যখন component-এ local state দরকার —
useState. -
যখন side-effect (API call, subscription, DOM updates) দরকার —
useEffect. -
ব্যার্কার হিসেবে মেমো/ক্যাশ দরকার —
useMemo/useCallback. -
জটিল state transitions হলে —
useReducer. -
DOM node রেফার করতে —
useRef.
Custom Hook = reusable logic
যদি একাধিক component একই ধরনের logic শেয়ার করে (API fetch, form handling, localStorage sync), সেটা extract করে custom hook বানান। custom hook নাম অবশ্যই use দিয়ে শুরু হবে (useFetch, useAuth ইত্যাদি)। custom hook React rule মেনে চলবে — hooks only at top level।
উদাহরণ — সহজ useFetch custom hook:
ব্যবহার:
2) useEffect এর ব্যবহার — patterns & pitfalls
useEffect হচ্ছে side-effects handle করার hook। signature: useEffect(effectFn, depsArray?).
প্যাটার্নস:
-
Mount only:
useEffect(()=>{ /* run once */ }, [])— componentDidMount মত। -
Deps change:
useEffect(()=>{/* run when x changes */}, [x]). -
Cleanup: effect ফাংশন একটি cleanup function return করতে পারে — unsubscribe, clear timers।
-
Async inside effect: effect নিজে async করা যাবে না (effect expects sync return for cleanup). তাই ভিতরে async function বানান।
Common examples:
-
Fetch on mount:
-
Debounced effect:
-
Subscription with cleanup:
Pitfalls & best practices:
-
Missing deps: eslint rule (
react-hooks/exhaustive-deps) সাহায্য করে—সব external variables effect এর dep list-এ দিন। না হলে stale closure বা bug হবে। -
Over-fetching: যদি deps দ্রুত পরিবর্তিত হয়, effect বারবার চলবে — debounce বা
useRefকৌশল ব্যবহার করুন। -
Race conditions: পরে আসা fetch আগের রেজাল্ট overwrite করতে পারে; use AbortController বা mounted flag ব্যবহার করুন।
-
Avoid heavy work directly: CPU-heavy কাজ effect এ সরাসরি না করে web worker বা memoization ব্যবহার করুন।
-
Don’t change state unconditionally without deps: e.g., effect->setState->re-render->effect triggers again => infinite loop। এই ক্ষেত্রে deps ঠিক করুন।
3) Component rendering performance — সাবধানে কী করবেন
প্রধান লক্ষ্য: অপ্রয়োজনীয় re-renders কমানো।
টেকনিকস:
-
Split components
-
বড় component কে ছোট করে দিন। ছোট component-এ শুধু প্রয়োজনীয় props পাঠান। এক ছোট পরিবর্তন পুরো UI রি-রেন্ডার কমায়।
-
-
React.memo-
functional component memoize করে — props একই থাকলে re-render skip।
-
-
যদি prop object বা function থাকে, ensure stable identity (useMemo/useCallback) বা provide custom comparison.
-
useCallbackএবংuseMemo-
useCallbackfunctions কে stable রাখে (prevent child re-render if function prop changes). -
useMemoexpensive value compute cache করে।
-
-
সতর্কতা: সব জায়গায় useMemo/useCallback লাগবে না — profiling আগে ব্যবহার করুন।
-
Keys & list rendering
-
list render এ unique, stable
keyব্যবহার করুন। index কেবলমাত্র static lists এ ব্যবহার করা উচিত নয়।
-
-
Avoid inline objects/functions in JSX
-
<Child onClick={() => doSomething(a)} data={{x}} />প্রতিবার নতুন prop পাঠায়। পরিবর্তে useCallback/useMemo.
-
-
Virtualization for long lists
-
react-windowবাreact-virtualizedব্যবহার করুন যদি লক্ষাধিক আইটেম থাকে।
-
-
Avoid unnecessary state derived from props
-
derive on render or memoize—duplicate sources of truth এড়ান।
-
-
Batching updates
-
React automatically batches in event handlers; in async callbacks use
unstable_batchedUpdates(rare) or React 18 behavior covers most cases.
-
-
Profile with React DevTools Profiler
-
কোন component বেশি সময় নিচ্ছে, কোথায় re-render হচ্ছে — আগে profile, পরে optimize.
-
-
CSS and DOM size
-
অনেক DOM elements থাকলে render slow হয় — minimize DOM depth/size.
4) SOLID Principles applied to React (simplified)
SOLID মূলত OOP pattern, কিন্তু UI components-এও উপকারী:
-
S — Single Responsibility Principle (SRP)
-
প্রতিটি component একটি কাজ করুক। (e.g.,
UserListdata fetch করে,UserItempresentation করে)
-
-
O — Open/Closed Principle
-
components extendable সেইভাবে লিখুন যাতে নতুন behavior add করতে props বা composition ব্যবহার করা যায়—modify না করে extend করা যায়। e.g., render prop বা children pattern।
-
-
L — Liskov Substitution Principle
-
যেসব components interchangeable হবে, তাদের contract (props shape) compatible রাখুন। (অর্থাৎ child class/component parent এর জায়গায় substitute করলে bug না হবে)
-
-
I — Interface Segregation Principle
-
বড় props object না দিয়ে ছোট, স্পষ্ট props রাখুন—components কেবল তাদের প্রয়োজনীয় props পাবে।
-
-
D — Dependency Inversion Principle
-
নির্ভরতাগুলো (e.g., services, API clients) component-এ 직접 বানানো না করে বাইরের দিকে inject করুন (context/provider বা props দিয়ে)। এভাবে টেস্টিং সহজ হয়।
-
উদাহরণ — SRP ও composition:
5) Global state — Zustand, Jotai, অন্যান্য জনপ্রিয় লাইব্রেরি (সমালোচনায়)
কখন global state দরকার?
-
অনেক দূরবর্তী Komponenten-এ থাকা state (auth, theme, cart, feature flags) — কিন্তু সবকিছু global করার দরকার নেই। প্রথমে consider local state, context, props drilling কমাতে লিফট আপ।
Popular options (সংক্ষেপে):
-
Context + useReducer (built-in)
-
সহজ অ্যাপ/মধ্যবিত্ত কাজে ভাল। কিন্তু বড় state/অতিরিক্ত frequent updates হলে performance সমস্যা হতে পারে কারণ context value change হলে সব subscriber re-render হতে পারে (memoize ও splitting দরকার)।
-
-
Zustand
-
API সহজ ও হালকা। store outside React; components শুধু selective slice subscribe করে — re-render কমায়।
-
উদাহরণ:
-
-
সুবিধা: small API, slices subscribe, middleware support (persist), minimal boilerplate।
-
Jotai
-
atom-based approach (fine-grained reactive atoms). প্রতিটি atom শুধু যেসব component use করে তাদেরই re-render করে — খুব modular।
-
উদাহরণ:
-
-
সুবিধা: simplicity, derived atoms, async atoms।
-
Redux (Toolkit)
-
বড় অ্যাপ যেখানে predictable state transitions, devtools, middleware লাগবে। Redux Toolkit (RTK) boilerplate অনেক কমিয়ে দেয়। কিন্তু learning curve ও boilerplate আছে (RTK ছাড়া কন্সিডার করবেন না)।
-
-
Recoil
-
atom/selectors ধারণা—Jotai যেমন। (ব্যবহার কমবেশি একই শ্রেণীর)।
-
কোনটা বেছে নেবেন?
-
ছোট/মিড অ্যাপ: Context + useReducer পর্যাপ্ত।
-
যদি ফাইন-গ্রেইন updates দরকার বা simple API চান: Zustand খুব ভালো।
-
যদি atom/derived reactive approach পছন্দ: Jotai।
-
বড়, complex state + middleware/devtools: Redux Toolkit।
Performance টিপস Global state-এ:
-
সাবস্ক্রাইব করুন শুধুমাত্র প্রয়োজনীয় slice-এ (zustand selector, jotai atoms)।
-
Context value জিনিসকে memoize করুন কনস্ট্যান্ট না হলে নতুন object প্রদান করবেন না।
-
Avoid storing large immutable objects that change often in global state — ক্যাশ/DB-synced approach consider করুন।
6) Context API — use cases, example, pitfalls
Context = global-ish dependency injection. Use case: theme, auth, locale, UI preferences.
Basic pattern:
ব্যবহার:
Pitfalls:
-
Large context value changes cause wide re-renders: যখন Provider value re-create হয় (e.g.,
{user, login, logout}প্রবতমান), তখন সব consumer re-render হবে। সমাধান:-
split context (authContext, themeContext আলাদা করুন)
-
value memoize করুন:
const value = useMemo(()=>({user, login, logout}), [user])— তবে functions স্থিতিশীল রাখার জন্য useCallback দরকার হলে ব্যবহার করুন।
-
-
Overuse: সব state context-এ রাখবেন না। শুধুই cross-cutting concerns রাখবেন।
-
Testing: wrapper provider দিয়ে test করুন, বা mock করার সহজ উপায় রাখুন।
কিছু বাস্তব-জীবনের টিপস ও patterns (প্র্যাক্টিক্যাল)
-
Start local, lift to global only when needed
-
প্রথমে component local state ব্যবহার করুন; যদি props drilling বেশি হয়, তখন context বা zustand বিবেচনা করুন।
-
-
Keep hooks pure and small
-
custom hooks single responsibility রাখুন (e.g.,
useAuthশুধু auth logic,useUserProfileশুধু profile fetch করে)। এতে reuse সহজ হয়।
-
-
Avoid premature optimization
-
profile করে bottleneck খুঁজুন।
useMemo/useCallback/React.memoতখনই ব্যবহার করুন যখন profiling দেখায় পুনরাবৃত্তি বেশি বা expensive render আছে।
-
-
Stable identities for handlers
-
parent থেকে child-এ callback পাঠাতে চাইলে useCallback ব্যবহার করুন। না হলে memoized child বারবার re-render পাবে।
-
-
Error boundaries
-
component tree crash রোধ করতে Error Boundary ব্যবহার করুন (class component দিয়ে)।
-
-
TypeScript (optional but recommended)
-
props ও state types না থাকলে বড় প্রজেক্টে bug বেশি হয়। TS use করলে hooks ও context safer হয়।
-
ছোট চেকলিস্ট (তৎক্ষণাৎ প্রয়োগযোগ্য)
-
যদি component বারবার re-render করে, React Profiler চালান।
-
ছোট components রাখুন, single responsibility বজায় রাখুন।
-
heavy computation হলে
useMemoব্যাবহার করুন (profiling দিয়ে validate করুন)। -
functions props পাঠালে
useCallbackবিবেচনা করুন। -
global state লাগলে প্রথমে context -> তারপর zustand/jotai/RTK evaluate করুন।
-
effect-এ async work করলে
AbortControllerবা mounted flag ব্যবহার করুন।
আমি এটাকে practical রাখতে কিছু সংক্ষিপ্ত উদাহরণ যোগ করলাম (একসাথে বড় উদাহরণ চাইলে আমি পূর্ণ mini-project দেব):
-
Custom hook + context combo (Auth + useAuthFetch):
-
Avoiding unnecessary re-renders with memo & callback:
No comments