renderToString
renderToString একটি React tree কে HTML string হিসেবে রেন্ডার করে।
const html = renderToString(reactNode, options?)রেফারেন্স
renderToString(reactNode, options?)
আপনার অ্যাপকে HTML এ রেন্ডার করতে, সার্ভার থেকে renderToString কল করুন।
import { renderToString } from 'react-dom/server';
const html = renderToString(<App />);সার্ভার-জেনারেটেড HTML কে ইন্টার্যাক্টিভ করতে, ক্লায়েন্ট থেকে hydrateRoot কল করুন।
প্যারামিটার্স
-
reactNode: একটি React node যাকে আপনি HTML এ রেন্ডার করতে চান। উদাহরণস্বরূপ,<App />এর মতো একটি JSX node । -
অপশনাল
options: সার্ভার রেন্ডারের জন্য একটি অবজেক্ট।- অপশনাল
identifierPrefix: একটি string prefix (উপসর্গ) যেটি ReactuseIdএর দ্বারা জেনারেট করা id এর সঙ্গে ব্যবহার করে। একই পেজে একাধিক root ব্যবহারের সময় আইডির সাথে আইডির সংঘর্ষ এড়াতে এটি উপকারে আসে। এটিhydrateRootএর কাছে পাস করা prefix এর অবশ্যই অনুরূপ হতে হবে।
- অপশনাল
রিটার্নস
একটি HTML স্ট্রিং।
সাবধানতা
-
renderToStringএর সীমিত Suspense সাপোর্ট রয়েছে। যদি কোনো কম্পোনেন্ট suspend করে,renderToStringকোনো বিলম্ব ছাড়াই সেটির fallback কে HTML হিসেবে পাঠিয়ে দেয়। -
renderToStringব্রাউজারে কাজ করে, কিন্তু ক্লায়েন্ট সাইডে এটির ব্যাবহার রিকমেন্ডেড না।
ব্যাবহার
একটি React tree কে HTML হিসেবে একটি স্ট্রিং-এ রেন্ডার করা
আপনার সার্ভার রেসপন্সের সাথে পাঠানোর জন্য আপনার অ্যাপকে একটি HTML স্ট্রিং-এ রেন্ডার করতে renderToString কল করুনঃ
import { renderToString } from 'react-dom/server';
// The route handler syntax depends on your backend framework
app.use('/', (request, response) => {
const html = renderToString(<App />);
response.send(html);
});এটি আপনার React কম্পোনেন্টগুলির প্রাথমিক নন-ইন্টারেক্টিভ HTML আউটপুট তৈরি করবে। ক্লায়েন্ট সাইডে, আপনাকে সেই সার্ভার-জেনারেটেড HTML কে হাইড্রেট এবং ইন্টারেক্টিভ করতে hydrateRoot কল করতে হবে।
বিকল্প সমূহ
সার্ভারে renderToString এর বদলে একটি streaming মেথড ব্যাবহার করা
renderToString সঙ্গে সঙ্গেই একটি স্ট্রিং রিটার্ন করে, তাই এটি স্ট্রিমিং বা ডেটার জন্য অপেক্ষা করা সাপোর্ট করে না।
যখন সম্ভব, আমরা এই fully-featured বিকল্পগুলো ব্যাবহার করা রেকমেন্ড করিঃ
- আপনি যদি Node.js ব্যবহার করেন, তাহলে
renderToPipeableStreamব্যবহার করুন। - আপনি যদি Deno বা Web Streams সহ একটি আধুনিক Edge রানটাইম ব্যবহার করেন, তাহলে
renderToReadableStreamব্যবহার করুন।
আপনার সার্ভার environment যদি stream সাপোর্ট না করে, তাহলে আপনি renderToString ব্যবহার চালিয়ে যেতে পারেন।
ক্লায়েন্ট কোড থেকে renderToString দূর করা
কখনো কখনো, কোনো কম্পোনেন্টকে HTML-এ রূপান্তর করতে ক্লায়েন্ট-সাইডে renderToString ব্যবহার করা হয়।
// 🚩 Unnecessary: using renderToString on the client
import { renderToString } from 'react-dom/server';
const html = renderToString(<MyIcon />);
console.log(html); // For example, "<svg>...</svg>"ক্লায়েন্ট-সাইডে react-dom/server ইমপোর্ট করা বিনা প্রয়োজনে আপনার বান্ডল সাইজ বাড়িয়ে দেয় এবং এটা এড়ানো উচিত। যদি আপনার ব্রাউজারে কোনো কম্পোনেন্টকে HTML-এ রেন্ডার করতে হয়, তাহলে createRoot ব্যবহার করুন এবং DOM থেকে HTML রিড করুনঃ
import { createRoot } from 'react-dom/client';
import { flushSync } from 'react-dom';
const div = document.createElement('div');
const root = createRoot(div);
flushSync(() => {
root.render(<MyIcon />);
});
console.log(div.innerHTML); // For example, "<svg>...</svg>"এখানে flushSync কল করা জরুরী যাতে DOM তার innerHTML প্রোপার্টি read করার আগে আপডেট হয়।
Troubleshooting
When a component suspends, the HTML always contains a fallback
renderToString does not fully support Suspense.
If some component suspends (for example, because it’s defined with lazy or fetches data), renderToString will not wait for its content to resolve. Instead, renderToString will find the closest <Suspense> boundary above it and render its fallback prop in the HTML. The content will not appear until the client code loads.
To solve this, use one of the recommended streaming solutions. They can stream content in chunks as it resolves on the server so that the user sees the page being progressively filled in before the client code loads.