spinny:~/writing $ less mastering-react-server-components.md
12React Server Components (RSC) আমরা কীভাবে React অ্যাপ্লিকেশন তৈরি করি তা মৌলিকভাবে পরিবর্তন করেছে। রেন্ডারিং লজিক সার্ভারে সরিয়ে, আমরা ক্লায়েন্টে পাঠানো JavaScript বান্ডেল উল্লেখযোগ্যভাবে কমাতে পারি, যা দ্রুত লোড টাইম এবং আরও ভালো ব্যবহারকারী অভিজ্ঞতার দিকে নিয়ে যায়। এই নিবন্ধে, আমরা ২০২৬ সালে RSCs ব্যবহারের জন্য উন্নত প্যাটার্ন এবং সেরা অনুশীলনগুলো অন্বেষণ করব।34## Server Components কী?56ঐতিহ্যগতভাবে, React components সম্পূর্ণরূপে ক্লায়েন্টে (CSR) রেন্ডার হতো অথবা সার্ভারে HTML হিসেবে প্রি-রেন্ডার (SSR) হতো এবং তারপর ক্লায়েন্টে হাইড্রেট হতো। **Server Components** আমাদের _একচেটিয়াভাবে_ সার্ভারে components রেন্ডার করতে দেয়। এদের কোড কখনো ব্রাউজারে পাঠানো হয় না।78### সুবিধাসমূহ9101. **শূন্য বান্ডেল সাইজ**: Server Components-এ ব্যবহৃত নির্ভরতা (যেমন markdown parsers বা ভারী date libraries) সার্ভারেই থাকে।112. **সরাসরি Backend অ্যাক্সেস**: আপনি API endpoints প্রকাশ না করেই আপনার component-এর ভেতরে সরাসরি ডাটাবেস কোয়েরি করতে পারেন।123. **স্বয়ংক্রিয় Code Splitting**: সার্ভার সাইডে import করা Client components স্বয়ংক্রিয়ভাবে কোড-স্প্লিট হয়।1314## ডেটা ফেচিং প্যাটার্ন1516RSC-তে, আপনি আপনার components-কে `async` করতে এবং সরাসরি ডেটা await করতে পারেন।1718```tsx19// app/users/page.tsx20import { db } from '@/lib/db';2122export default async function UsersPage() {23 const users = await db.user.findMany();2425 return (26 <main>27 <h1>Users</h1>28 <ul>29 {users.map((user) => (30 <li key={user.id}>{user.name}</li>31 ))}32 </ul>33 </main>34 );35}36```3738### Streaming-এর জন্য Suspense3940যেহেতু ডেটা ফেচিং ধীর হতে পারে, ডেটা লোড হওয়ার সময় তাৎক্ষণিকভাবে একটি ফলব্যাক UI দেখাতে আপনার components-কে `<Suspense>`-এ wrap করুন।4142```tsx43import { Suspense } from 'react';44import UserList from './UserList';45import LoadingSkeleton from './LoadingSkeleton';4647export default function Page() {48 return (49 <section>50 <h1>My Users</h1>51 <Suspense fallback={<LoadingSkeleton />}>52 <UserList />53 </Suspense>54 </section>55 );56}57```5859## Server এবং Client Components মিশ্রিত করা6061সবচেয়ে বিভ্রান্তিকর দিকগুলোর একটি হলো Server এবং Client components কীভাবে একত্রিত করা যায়।6263**মূলনীতি**: Server Components Client Components import করতে পারে। Client Components _সরাসরি_ Server Components import করতে _পারে না_। তবে, আপনি একটি Server Component-কে `children` হিসেবে একটি Client Component-এ পাস করতে পারেন।6465### "Children" প্যাটার্ন6667```tsx68// ClientComponent.tsx69'use client';7071import { useState } from 'react';7273export default function ClientWrapper({ children }) {74 const [count, setCount] = useState(0);7576 return (77 <div onClick={() => setCount((c) => c + 1)}>78 Count: {count}79 {children} {/* This can be a Server Component! */}80 </div>81 );82}83```8485```tsx86// ServerPage.tsx87import ClientWrapper from './ClientWrapper';88import ServerContent from './ServerContent';8990export default function Page() {91 return (92 <ClientWrapper>93 <ServerContent /> {/* This works perfectly */}94 </ClientWrapper>95 );96}97```9899## সাধারণ সমস্যাসমূহ1001011. **Server Components-এ Context ব্যবহার**: Context একটি ক্লায়েন্ট-সাইড ধারণা। সার্ভার সাইডে ডেটা শেয়ার করতে হলে, props হিসেবে পাস করুন অথবা একটি বিশেষায়িত request-scope cache ব্যবহার করুন।1022. **Event Handlers যোগ করা**: আপনি একটি Server Component-এ `onClick` বা `onChange` যোগ করতে পারবেন না। সেই লজিক একটি জেনেরিক Client Component লিফ নোডে রাখতে হবে।103104## উপসংহার105106React Server Components শুধু একটি ফিচার নয়; এটি একটি প্যারাডাইম শিফট। সার্ভার এবং ক্লায়েন্টের মধ্যে সীমানা বুঝে, আপনি এমন অ্যাপ্লিকেশন তৈরি করতে পারেন যা উচ্চ মাত্রায় ইন্টারেক্টিভ এবং অবিশ্বাস্যভাবে দ্রুত।107
:২০২৬ সালে React Server Components আয়ত্ত করাlines 1-107 (END) — press q to close