রিঅ্যাক্ট-স্ন্যাপ সহ প্রি-রেন্ডার রুট

সার্ভার-সাইড রেন্ডারিং নয় তবে এখনও আপনার প্রতিক্রিয়া সাইটের কর্মক্ষমতা বাড়াতে চান? প্রি-রেন্ডারিং চেষ্টা করুন!

react-snap হল একটি তৃতীয় পক্ষের লাইব্রেরি যা আপনার সাইটের পৃষ্ঠাগুলিকে স্ট্যাটিক HTML ফাইলে প্রি-রেন্ডার করে। এটি আপনার অ্যাপ্লিকেশনে প্রথম পেইন্ট সময় উন্নত করতে পারে।

এখানে একটি সিমুলেটেড 3G সংযোগ এবং মোবাইল ডিভাইসে লোড করা প্রি-রেন্ডারিং সহ এবং ছাড়া একই অ্যাপ্লিকেশনটির তুলনা করা হয়েছে:

পাশাপাশি লোডিং তুলনা। প্রি-রেন্ডারিং ব্যবহার করা সংস্করণটি 4.2 সেকেন্ড দ্রুত লোড হয়।

কেন এই দরকারী?

বৃহৎ একক-পৃষ্ঠার অ্যাপ্লিকেশনগুলির প্রধান কর্মক্ষমতা সমস্যা হল যে ব্যবহারকারীকে জাভাস্ক্রিপ্ট বান্ডিল(গুলি) এর জন্য অপেক্ষা করতে হবে যা সাইটটি ডাউনলোড শেষ করার জন্য তৈরি করে তারা কোনো বাস্তব বিষয়বস্তু দেখার আগে। বান্ডেল যত বড় হবে, ব্যবহারকারীকে তত বেশি অপেক্ষা করতে হবে।

এটি সমাধান করার জন্য, অনেক বিকাশকারী শুধুমাত্র ব্রাউজারে এটি বুট করার পরিবর্তে সার্ভারে অ্যাপ্লিকেশন রেন্ডার করার পদ্ধতি গ্রহণ করে। প্রতিটি পৃষ্ঠা/রুট ট্রানজিশনের সাথে, সার্ভারে সম্পূর্ণ এইচটিএমএল তৈরি হয় এবং ব্রাউজারে পাঠানো হয়, যা ফার্স্ট পেইন্টের সময় কমিয়ে দেয় কিন্তু ফার্স্ট বাইট থেকে ধীর সময়ের খরচে আসে।

প্রি-রেন্ডারিং হল একটি পৃথক কৌশল যা সার্ভার রেন্ডারিংয়ের চেয়ে কম জটিল, তবে আপনার অ্যাপ্লিকেশনে ফার্স্ট পেইন্ট সময় উন্নত করার একটি উপায়ও প্রদান করে। একটি হেডলেস ব্রাউজার, বা ইউজার ইন্টারফেস ছাড়া একটি ব্রাউজার, বিল্ড টাইমে প্রতিটি রুটের স্ট্যাটিক HTML ফাইল তৈরি করতে ব্যবহৃত হয়। এই ফাইলগুলিকে জাভাস্ক্রিপ্ট বান্ডিলগুলির সাথে পাঠানো যেতে পারে যা অ্যাপ্লিকেশনটির জন্য প্রয়োজনীয়৷

প্রতিক্রিয়া

react-snap আপনার অ্যাপ্লিকেশনে বিভিন্ন রুটের পূর্ব-রেন্ডার করা HTML ফাইল তৈরি করতে Puppeteer ব্যবহার করে। শুরু করতে, এটি একটি বিকাশ নির্ভরতা হিসাবে ইনস্টল করুন:

npm install --save-dev react-snap

তারপর আপনার package.json এ একটি postbuild স্ক্রিপ্ট যোগ করুন:

"scripts": {
  //...
  "postbuild": "react-snap"
}

প্রতিবার তৈরি করা অ্যাপ্লিকেশনগুলির একটি নতুন বিল্ড ( npm build ) হলে এটি স্বয়ংক্রিয়ভাবে react-snap কমান্ডটি চালাবে।

আপনাকে যা করতে হবে তা হল অ্যাপ্লিকেশনটি বুট করার পদ্ধতিটি পরিবর্তন করা। নিম্নলিখিত src/index.js ফাইলটি পরিবর্তন করুন:

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';

ReactDOM.render(<App />, document.getElementById('root'));
const rootElement = document.getElementById("root");

if (rootElement.hasChildNodes()) {
  ReactDOM.hydrate(<App />, rootElement);
} else {
  ReactDOM.render(<App />, rootElement);
}

সরাসরি DOM-এ রুট রিঅ্যাক্ট এলিমেন্ট রেন্ডার করার জন্য শুধুমাত্র ReactDOM.render ব্যবহার করার পরিবর্তে, এইচটিএমএল বিষয়বস্তু প্রি-রেন্ডার করা হয়েছে (বা সার্ভারে রেন্ডার করা হয়েছে) কিনা তা নির্ধারণ করতে কোনো চাইল্ড নোড ইতিমধ্যেই উপস্থিত আছে কিনা তা পরীক্ষা করে। যদি তাই হয়, ReactDOM.hydrate শ্রোতাদের ইভেন্ট শ্রোতাদেরকে নতুন করে তৈরি করার পরিবর্তে ইতিমধ্যে তৈরি করা HTML এর সাথে সংযুক্ত করতে ব্যবহার করা হয়।

অ্যাপ্লিকেশনটি তৈরি করা এখন ক্রল করা প্রতিটি রুটের জন্য পেলোড হিসাবে স্ট্যাটিক HTML ফাইল তৈরি করবে। আপনি HTML অনুরোধের URL-এ ক্লিক করে এবং তারপর Chrome DevTools-এর মধ্যে প্রিভিউ ট্যাবে ক্লিক করে HTML পেলোড কেমন দেখাচ্ছে তা দেখতে পারেন৷

একটি আগে এবং পরে তুলনা. আফটার শট দেখায় বিষয়বস্তু রেন্ডার হয়েছে।

স্টাইল না করা বিষয়বস্তুর ফ্ল্যাশ

যদিও স্ট্যাটিক এইচটিএমএল এখন প্রায় সঙ্গে সঙ্গে রেন্ডার করা হয়, তবুও এটি ডিফল্টরূপে আনস্টাইল করা থাকে যা "আনস্টাইল না করা সামগ্রীর ফ্ল্যাশ" (এফওইসি) দেখানোর সমস্যা সৃষ্টি করতে পারে। এটি বিশেষভাবে লক্ষণীয় হতে পারে যদি আপনি নির্বাচকদের তৈরি করতে একটি CSS-in-JS লাইব্রেরি ব্যবহার করেন কারণ জাভাস্ক্রিপ্ট বান্ডেলকে কোনো শৈলী প্রয়োগ করার আগে কার্যকর করা শেষ করতে হবে।

এটি প্রতিরোধে সাহায্য করার জন্য, সমালোচনামূলক CSS বা ন্যূনতম পরিমাণ CSS যা প্রারম্ভিক পৃষ্ঠাটি রেন্ডার করার জন্য প্রয়োজন, সরাসরি HTML নথির <head> এ ইনলাইন করা যেতে পারে। react-snap বিভিন্ন রুটের জন্য যেকোনো গুরুত্বপূর্ণ CSS বের করতে হুড, minimalcss অধীনে আরেকটি তৃতীয়-পক্ষের লাইব্রেরি ব্যবহার করে। আপনি আপনার package.json ফাইলে নিম্নলিখিত উল্লেখ করে এটি সক্ষম করতে পারেন:

"reactSnap": {
  "inlineCss": true
}

Chrome DevTools-এ প্রতিক্রিয়া পূর্বরূপ দেখে নেওয়া এখন সমালোচনামূলক CSS ইনলাইন সহ স্টাইল করা পৃষ্ঠা দেখাবে।

একটি আগে এবং পরে তুলনা. আফটার শট দেখায় কন্টেন্ট রেন্ডার হয়েছে এবং স্টাইল করা হয়েছে কারণ ইনলাইন করা সমালোচনামূলক CSS।

উপসংহার

আপনি যদি আপনার অ্যাপ্লিকেশনে সার্ভার-সাইড রেন্ডারিং রুট না হন, তাহলে আপনার ব্যবহারকারীদের কাছে স্ট্যাটিক HTML প্রি-রেন্ডার করতে react-snap ব্যবহার করুন।

  1. এটি একটি বিকাশ নির্ভরতা হিসাবে ইনস্টল করুন এবং শুধুমাত্র ডিফল্ট সেটিংস দিয়ে শুরু করুন।
  2. পরীক্ষামূলক inlineCss বিকল্পটি ব্যবহার করুন যদি এটি আপনার সাইটের জন্য কাজ করে তাহলে সমালোচনামূলক CSS ইনলাইন করুন।
  3. আপনি যদি কোনো রুটের মধ্যে কম্পোনেন্ট লেভেলে কোড স্প্লিটিং ব্যবহার করেন, তাহলে আপনার ব্যবহারকারীদের কাছে লোডিং স্টেট প্রি-রেন্ডার না করার বিষয়ে সতর্ক থাকুন। react-snap README এটিকে আরও বিস্তারিতভাবে কভার করে।