বড় জাভাস্ক্রিপ্ট সম্পদ লোড করা পৃষ্ঠার গতিকে উল্লেখযোগ্যভাবে প্রভাবিত করে। আপনার জাভাস্ক্রিপ্টকে ছোট ছোট খণ্ডে বিভক্ত করা এবং স্টার্টআপের সময় একটি পৃষ্ঠার কাজ করার জন্য যা প্রয়োজন তা ডাউনলোড করা আপনার পৃষ্ঠার লোড প্রতিক্রিয়াশীলতাকে ব্যাপকভাবে উন্নত করতে পারে, যার ফলে আপনার পৃষ্ঠার নেক্সট পেইন্ট (INP) এর সাথে ইন্টারঅ্যাকশন উন্নত হতে পারে।
একটি পৃষ্ঠা ডাউনলোড, পার্স এবং বড় জাভাস্ক্রিপ্ট ফাইল কম্পাইল করার সময়, এটি সময়ের জন্য অপ্রতিক্রিয়াশীল হতে পারে। পৃষ্ঠার উপাদানগুলি দৃশ্যমান, কারণ সেগুলি একটি পৃষ্ঠার প্রাথমিক HTML এর একটি অংশ এবং CSS দ্বারা স্টাইল করা হয়েছে৷ যাইহোক, যেহেতু জাভাস্ক্রিপ্টের সেই ইন্টারেক্টিভ উপাদানগুলিকে শক্তির প্রয়োজন হয়—সেইসাথে পৃষ্ঠা দ্বারা লোড করা অন্যান্য স্ক্রিপ্টগুলি-তাদের কাজ করার জন্য জাভাস্ক্রিপ্ট পার্সিং এবং এক্সিকিউট করা হতে পারে। ফলাফল হল যে ব্যবহারকারীর মনে হতে পারে যেন মিথস্ক্রিয়াটি উল্লেখযোগ্যভাবে বিলম্বিত হয়েছে, বা এমনকি সম্পূর্ণভাবে ভেঙে গেছে।
এটি প্রায়শই ঘটে কারণ প্রধান থ্রেড ব্লক করা হয়, কারণ জাভাস্ক্রিপ্ট পার্স করা হয় এবং প্রধান থ্রেডে কম্পাইল করা হয়। যদি এই প্রক্রিয়াটি খুব বেশি সময় নেয়, তাহলে ইন্টারেক্টিভ পৃষ্ঠার উপাদানগুলি ব্যবহারকারীর ইনপুটের জন্য যথেষ্ট দ্রুত সাড়া নাও দিতে পারে। এর একটি প্রতিকার হল পৃষ্ঠাটি কাজ করার জন্য আপনার প্রয়োজন শুধুমাত্র জাভাস্ক্রিপ্ট লোড করা, যখন কোড স্প্লিটিং নামে পরিচিত একটি কৌশলের মাধ্যমে অন্যান্য জাভাস্ক্রিপ্টকে পরে লোড করার জন্য স্থগিত করা। এই মডিউলটি এই দুটি কৌশলের শেষের দিকে ফোকাস করে।
কোড স্প্লিটিং এর মাধ্যমে স্টার্টআপের সময় জাভাস্ক্রিপ্ট পার্সিং এবং এক্সিকিউশন হ্রাস করুন
জাভাস্ক্রিপ্ট এক্সিকিউশনে 2 সেকেন্ডের বেশি সময় লাগলে এবং 3.5 সেকেন্ডের বেশি সময় লাগলে ব্যর্থ হলে লাইটহাউস একটি সতর্কবার্তা দেয়। অত্যধিক জাভাস্ক্রিপ্ট পার্সিং এবং এক্সিকিউশন পৃষ্ঠার লাইফসাইকেলের যেকোন সময়ে একটি সম্ভাব্য সমস্যা, কারণ এতে একটি ইন্টারঅ্যাকশনের ইনপুট বিলম্ব বাড়ানোর সম্ভাবনা থাকে যদি ব্যবহারকারী পৃষ্ঠার সাথে ইন্টারঅ্যাক্ট করার সময়টি প্রক্রিয়াকরণের জন্য দায়ী প্রধান থ্রেড কাজগুলির সাথে মিলে যায়। এবং এক্সিকিউটিং জাভাস্ক্রিপ্ট চলছে।
তার চেয়েও বেশি, অত্যধিক জাভাস্ক্রিপ্ট এক্সিকিউশন এবং পার্সিং প্রাথমিক পৃষ্ঠা লোডের সময় বিশেষভাবে সমস্যাযুক্ত, কারণ এটি পৃষ্ঠার জীবনচক্রের বিন্দু যে ব্যবহারকারীদের পৃষ্ঠাটির সাথে ইন্টারঅ্যাক্ট করার সম্ভাবনা রয়েছে। প্রকৃতপক্ষে, টোটাল ব্লকিং টাইম (TBT) -একটি লোড রেসপন্সিভনেস মেট্রিক— আইএনপি- এর সাথে অত্যন্ত সম্পর্কযুক্ত , এটি পরামর্শ দেয় যে প্রাথমিক পৃষ্ঠা লোডের সময় ব্যবহারকারীদের ইন্টারঅ্যাকশনের চেষ্টা করার উচ্চ প্রবণতা রয়েছে৷
লাইটহাউস অডিট যা আপনার পৃষ্ঠার অনুরোধের প্রতিটি জাভাস্ক্রিপ্ট ফাইল কার্যকর করার সময় ব্যয় করা সময় রিপোর্ট করে যে এটি আপনাকে ঠিক কোন স্ক্রিপ্টগুলি কোড বিভাজনের জন্য প্রার্থী হতে পারে তা সনাক্ত করতে সাহায্য করতে পারে৷ তারপরে আপনি Chrome DevTools-এ কভারেজ টুল ব্যবহার করে পৃষ্ঠা লোডের সময় পৃষ্ঠার জাভাস্ক্রিপ্টের কোন অংশগুলি অব্যবহৃত হয়েছে তা শনাক্ত করতে আরও এগিয়ে যেতে পারেন।
কোড বিভাজন একটি দরকারী কৌশল যা একটি পৃষ্ঠার প্রাথমিক জাভাস্ক্রিপ্ট পেলোড কমাতে পারে। এটি আপনাকে একটি জাভাস্ক্রিপ্ট বান্ডিলকে দুটি অংশে বিভক্ত করতে দেয়:
- পৃষ্ঠা লোডের সময় জাভাস্ক্রিপ্টের প্রয়োজন, এবং তাই অন্য কোনো সময়ে লোড করা যাবে না।
- অবশিষ্ট জাভাস্ক্রিপ্ট যা পরবর্তী সময়ে লোড করা যেতে পারে, বেশিরভাগ ক্ষেত্রেই ব্যবহারকারী পৃষ্ঠার একটি প্রদত্ত ইন্টারেক্টিভ উপাদানের সাথে ইন্টারঅ্যাক্ট করে।
ডায়নামিক import()
সিনট্যাক্স ব্যবহার করে কোড স্প্লিটিং করা যেতে পারে। এই সিনট্যাক্স - <script>
উপাদানগুলির বিপরীতে যা স্টার্টআপের সময় একটি প্রদত্ত জাভাস্ক্রিপ্ট রিসোর্সকে অনুরোধ করে - পৃষ্ঠা জীবনচক্রের সময় পরবর্তী সময়ে একটি জাভাস্ক্রিপ্ট সংস্থানের জন্য একটি অনুরোধ করে৷
document.querySelectorAll('#myForm input').addEventListener('blur', async () => {
// Get the form validation named export from the module through destructuring:
const { validateForm } = await import('/validate-form.mjs');
// Validate the form:
validateForm();
}, { once: true });
পূর্ববর্তী জাভাস্ক্রিপ্ট স্নিপেটে, validate-form.mjs
মডিউলটি ডাউনলোড, পার্স এবং এক্সিকিউট করা হয় শুধুমাত্র যখন একজন ব্যবহারকারী একটি ফর্মের <input>
ক্ষেত্রগুলিকে অস্পষ্ট করে । এই পরিস্থিতিতে, জাভাস্ক্রিপ্ট রিসোর্সটি ফর্মের বৈধতা লজিক চালনার জন্য দায়ী শুধুমাত্র তখনই পৃষ্ঠার সাথে জড়িত থাকে যখন এটি বাস্তবে ব্যবহৃত হওয়ার সম্ভাবনা বেশি থাকে।
ওয়েবপ্যাক , পার্সেল , রোলআপ , এবং esbuild এর মত JavaScript বান্ডলারগুলিকে জাভাস্ক্রিপ্ট বান্ডেলগুলিকে ছোট খণ্ডে বিভক্ত করার জন্য কনফিগার করা যেতে পারে যখনই তারা আপনার সোর্স কোডে একটি ডায়নামিক import()
কলের সম্মুখীন হয়৷ এই টুলগুলির বেশিরভাগই এটি স্বয়ংক্রিয়ভাবে করে, কিন্তু বিশেষ করে esbuild-এর জন্য আপনাকে এই অপ্টিমাইজেশানটি বেছে নিতে হবে।
কোড বিভাজনে সহায়ক নোট
যদিও কোড স্প্লিটিং হল প্রাথমিক পৃষ্ঠা লোডের সময় মূল থ্রেডের বিতর্ক কমানোর একটি কার্যকর পদ্ধতি, আপনি যদি কোড বিভাজনের সুযোগের জন্য আপনার JavaScript সোর্স কোড অডিট করার সিদ্ধান্ত নেন তবে এটি কিছু জিনিস মাথায় রাখতে হবে।
আপনি যদি পারেন একটি বান্ডলার ব্যবহার করুন
ডেভেলপারদের ডেভেলপমেন্ট প্রক্রিয়া চলাকালীন জাভাস্ক্রিপ্ট মডিউল ব্যবহার করা সাধারণ অভ্যাস। এটি একটি চমৎকার বিকাশকারীর অভিজ্ঞতার উন্নতি যা কোড পঠনযোগ্যতা এবং রক্ষণাবেক্ষণযোগ্যতা উন্নত করে। যাইহোক, জাভাস্ক্রিপ্ট মডিউল উৎপাদনে শিপিং করার সময় কিছু সাবঅপ্টিমাল কর্মক্ষমতা বৈশিষ্ট্য রয়েছে।
সবচেয়ে গুরুত্বপূর্ণ, আপনার সোর্স কোড প্রসেস এবং অপ্টিমাইজ করার জন্য আপনার একটি বান্ডলার ব্যবহার করা উচিত, যার মধ্যে আপনি কোড স্প্লিট করতে চান এমন মডিউলগুলি সহ। বান্ডলারগুলি শুধুমাত্র জাভাস্ক্রিপ্ট সোর্স কোডে অপ্টিমাইজেশান প্রয়োগ করতে খুব কার্যকর নয়, তারা কম্প্রেশন অনুপাতের বিপরীতে বান্ডেলের আকারের মতো কর্মক্ষমতা বিবেচনার ভারসাম্য বজায় রাখতেও বেশ কার্যকর। কম্প্রেশন কার্যকারিতা বান্ডিলের আকারের সাথে বৃদ্ধি পায়, তবে বান্ডেলরা নিশ্চিত করার চেষ্টা করে যে বান্ডিলগুলি এত বড় না হয় যে স্ক্রিপ্ট মূল্যায়নের কারণে তাদের দীর্ঘ কাজ করতে হয়।
বান্ডলাররা নেটওয়ার্কের মাধ্যমে প্রচুর সংখ্যক আনবান্ডেড মডিউল পাঠানোর সমস্যা এড়ায়। জাভাস্ক্রিপ্ট মডিউল ব্যবহার করে এমন আর্কিটেকচারে বড়, জটিল মডিউল ট্রি থাকে। যখন মডিউল ট্রিগুলিকে আনবান্ড করা হয়, তখন প্রতিটি মডিউল একটি পৃথক HTTP অনুরোধের প্রতিনিধিত্ব করে এবং আপনি যদি মডিউলগুলি বান্ডিল না করেন তবে আপনার ওয়েব অ্যাপে ইন্টারঅ্যাক্টিভিটি বিলম্বিত হতে পারে৷ যত তাড়াতাড়ি সম্ভব বড় মডিউল ট্রি লোড করার জন্য <link rel="modulepreload">
রিসোর্স ইঙ্গিত ব্যবহার করা সম্ভব, জাভাস্ক্রিপ্ট বান্ডেলগুলি লোডিং কর্মক্ষমতা দৃষ্টিকোণ থেকে এখনও পছন্দনীয়৷
অসাবধানতাবশত স্ট্রিমিং সংকলন অক্ষম করবেন না
আপনার প্রোডাকশন জাভাস্ক্রিপ্ট কোড যতটা সম্ভব দক্ষতার সাথে লোড হচ্ছে তা নিশ্চিত করতে Chromium-এর V8 JavaScript ইঞ্জিন অনেকগুলি অপ্টিমাইজেশন অফার করে। এই অপ্টিমাইজেশনগুলির মধ্যে একটি স্ট্রিমিং কম্পাইলেশন নামে পরিচিত যা ব্রাউজারে স্ট্রিম করা এইচটিএমএল-এর ক্রমবর্ধমান পার্সিংয়ের মতো- নেটওয়ার্ক থেকে আসার সাথে সাথে জাভাস্ক্রিপ্টের স্ট্রিম করা অংশগুলিকে কম্পাইল করে।
Chromium-এ আপনার ওয়েব অ্যাপ্লিকেশনের জন্য স্ট্রিমিং সংকলন ঘটে তা নিশ্চিত করার জন্য আপনার কাছে কয়েকটি উপায় রয়েছে:
- জাভাস্ক্রিপ্ট মডিউল ব্যবহার এড়াতে আপনার প্রোডাকশন কোড রূপান্তর করুন। বান্ডলাররা আপনার জাভাস্ক্রিপ্ট সোর্স কোডকে একটি সংকলন লক্ষ্যের উপর ভিত্তি করে রূপান্তর করতে পারে এবং লক্ষ্যটি প্রায়শই একটি নির্দিষ্ট পরিবেশের জন্য নির্দিষ্ট হয়। V8 যেকোন জাভাস্ক্রিপ্ট কোডে স্ট্রিমিং সংকলন প্রয়োগ করবে যা মডিউল ব্যবহার করে না এবং আপনি আপনার জাভাস্ক্রিপ্ট মডিউল কোডটিকে একটি সিনট্যাক্সে রূপান্তর করতে আপনার বান্ডলারকে কনফিগার করতে পারেন যা জাভাস্ক্রিপ্ট মডিউল এবং তাদের বৈশিষ্ট্যগুলি ব্যবহার করে না।
- আপনি যদি জাভাস্ক্রিপ্ট মডিউল উৎপাদনে পাঠাতে চান তাহলে
.mjs
এক্সটেনশন ব্যবহার করুন। আপনার প্রোডাকশন জাভাস্ক্রিপ্ট মডিউল ব্যবহার করুক বা না করুক, জাভাস্ক্রিপ্টের জন্য কোন বিশেষ কন্টেন্ট টাইপ নেই যা মডিউল ব্যবহার করে বনাম জাভাস্ক্রিপ্ট যা করে না। যেখানে V8 উদ্বিগ্ন, আপনি.js
এক্সটেনশন ব্যবহার করে জাভাস্ক্রিপ্ট মডিউল উৎপাদনে পাঠালে আপনি কার্যকরভাবে স্ট্রিমিং সংকলন থেকে অপ্ট আউট করেন। আপনি যদি জাভাস্ক্রিপ্ট মডিউলের জন্য.mjs
এক্সটেনশন ব্যবহার করেন, V8 নিশ্চিত করতে পারে যে মডিউল-ভিত্তিক জাভাস্ক্রিপ্ট কোডের জন্য স্ট্রিমিং সংকলন ভাঙা হয়নি।
এই বিবেচনাগুলি আপনাকে কোড বিভাজন ব্যবহার থেকে বিরত করবেন না। কোড স্প্লিটিং হল ব্যবহারকারীদের কাছে প্রাথমিক জাভাস্ক্রিপ্ট পেলোড কমানোর একটি কার্যকর উপায়, কিন্তু একটি বান্ডলার ব্যবহার করে এবং কীভাবে আপনি V8 এর স্ট্রিমিং সংকলন আচরণ সংরক্ষণ করতে পারেন তা জেনে, আপনি নিশ্চিত করতে পারেন যে আপনার উৎপাদন জাভাস্ক্রিপ্ট কোড ব্যবহারকারীদের জন্য যত দ্রুত হতে পারে।
গতিশীল আমদানি ডেমো
ওয়েবপ্যাক
SplitChunksPlugin
নামের একটি প্লাগইন সহ ওয়েবপ্যাক পাঠানো হয়, যা আপনাকে কনফিগার করতে দেয় কিভাবে বান্ডলার জাভাস্ক্রিপ্ট ফাইলগুলিকে বিভক্ত করে। ওয়েবপ্যাক গতিশীল import()
এবং স্ট্যাটিক import
বিবৃতি উভয়কেই স্বীকৃতি দেয়। SplitChunksPlugin
এর আচরণ কনফিগারেশনে chunks
বিকল্প উল্লেখ করে পরিবর্তন করা যেতে পারে:
-
chunks: async
হল ডিফল্ট মান, এবং ডায়নামিকimport()
কলকে বোঝায়। -
chunks: initial
স্ট্যাটিকimport
কল বোঝায়। -
chunks: all
ডাইনামিকimport()
এবং স্ট্যাটিক ইম্পোর্ট উভয়কেই কভার করে, আপনাকেasync
এবংinitial
আমদানির মধ্যে অংশ ভাগ করতে দেয়৷
ডিফল্টরূপে, যখনই ওয়েবপ্যাক একটি ডায়নামিক import()
স্টেটমেন্টের সম্মুখীন হয়। এটি সেই মডিউলের জন্য একটি পৃথক খণ্ড তৈরি করে:
/* main.js */
// An application-specific chunk required during the initial page load:
import myFunction from './my-function.js';
myFunction('Hello world!');
// If a specific condition is met, a separate chunk is downloaded on demand,
// rather than being bundled with the initial chunk:
if (condition) {
// Assumes top-level await is available. More info:
// https://v8.dev/features/top-level-await
await import('/form-validation.js');
}
পূর্ববর্তী কোড স্নিপেটের জন্য ডিফল্ট ওয়েবপ্যাক কনফিগারেশন দুটি পৃথক অংশে পরিণত হয়:
-
main.js
খণ্ড—যা ওয়েবপ্যাককেinitial
খণ্ড হিসেবে শ্রেণীবদ্ধ করে—যাতেmain.js
এবং./my-function.js
মডিউল অন্তর্ভুক্ত রয়েছে। -
async
খণ্ড, যা শুধুমাত্রform-validation.js
অন্তর্ভুক্ত করে (যদি কনফিগার করা থাকে তবে সম্পদের নামে একটি ফাইল হ্যাশ রয়েছে)। এই অংশটি শুধুমাত্র ডাউনলোড করা হয় যদি এবং যখনcondition
সত্য হয়।
এই কনফিগারেশনটি আপনাকে form-validation.js
খণ্ডটি লোড করা পিছিয়ে দিতে দেয় যতক্ষণ না এটি আসলে প্রয়োজন হয়। এটি প্রাথমিক পৃষ্ঠা লোডের সময় স্ক্রিপ্ট মূল্যায়নের সময় হ্রাস করে লোড প্রতিক্রিয়াশীলতা উন্নত করতে পারে। form-validation.js
খণ্ডের জন্য স্ক্রিপ্ট ডাউনলোড এবং মূল্যায়ন ঘটে যখন একটি নির্দিষ্ট শর্ত পূরণ করা হয়, এই ক্ষেত্রে, গতিশীলভাবে আমদানি করা মডিউল ডাউনলোড করা হয়। একটি উদাহরণ এমন একটি শর্ত হতে পারে যেখানে একটি পলিফিল শুধুমাত্র একটি নির্দিষ্ট ব্রাউজারের জন্য ডাউনলোড করা হয়, বা - আগের উদাহরণের মতো - ব্যবহারকারীর ইন্টারঅ্যাকশনের জন্য আমদানি করা মডিউলটি প্রয়োজনীয়৷
অন্যদিকে, খণ্ডগুলি নির্দিষ্ট করতে SplitChunksPlugin
কনফিগারেশন পরিবর্তন করা chunks: initial
নিশ্চিত করে যে কোড শুধুমাত্র প্রাথমিক অংশগুলিতে বিভক্ত করা হয়েছে। এগুলি হল স্থিরভাবে আমদানি করা বা ওয়েবপ্যাকের entry
প্রপার্টিতে তালিকাভুক্ত। পূর্ববর্তী উদাহরণের দিকে তাকালে, ফলস্বরূপ অংশটি একটি একক স্ক্রিপ্ট ফাইলে form-validation.js
এবং main.js
এর সংমিশ্রণ হবে, যার ফলে প্রাথমিক পৃষ্ঠা লোডের কার্যকারিতা আরও খারাপ হবে।
SplitChunksPlugin
এর বিকল্পগুলিও বড় স্ক্রিপ্টগুলিকে একাধিক ছোট স্ক্রিপ্টে আলাদা করার জন্য কনফিগার করা যেতে পারে-উদাহরণস্বরূপ, maxSize
দ্বারা নির্দিষ্ট করা সীমা ছাড়িয়ে গেলে ওয়েবপ্যাককে খণ্ডগুলিকে আলাদা ফাইলে ভাগ করতে নির্দেশ দেওয়ার জন্য maxSize
বিকল্পটি ব্যবহার করে। বড় স্ক্রিপ্ট ফাইলগুলিকে ছোট ফাইলে বিভক্ত করা লোড প্রতিক্রিয়াশীলতাকে উন্নত করতে পারে , কারণ কিছু ক্ষেত্রে সিপিইউ-নিবিড় স্ক্রিপ্ট মূল্যায়ন কাজকে ছোট ছোট কাজগুলিতে ভাগ করা হয়, যা দীর্ঘ সময়ের জন্য মূল থ্রেডটিকে ব্লক করার সম্ভাবনা কম।
উপরন্তু, বৃহত্তর জাভাস্ক্রিপ্ট ফাইল তৈরি করার মানে হল যে স্ক্রিপ্টগুলি ক্যাশে অকার্যকর হওয়ার সম্ভাবনা বেশি। উদাহরণস্বরূপ, আপনি যদি ফ্রেমওয়ার্ক এবং প্রথম-পক্ষের অ্যাপ্লিকেশন কোড উভয়ের সাথে একটি খুব বড় স্ক্রিপ্ট পাঠান, তবে শুধুমাত্র ফ্রেমওয়ার্ক আপডেট করা হলে পুরো বান্ডিলটি অবৈধ হয়ে যেতে পারে, তবে বান্ডেল করা সংস্থানে আর কিছুই না।
অন্যদিকে, ছোট স্ক্রিপ্ট ফাইলগুলি রিটার্ন ভিজিটর ক্যাশে থেকে রিসোর্স পুনরুদ্ধার করার সম্ভাবনা বাড়িয়ে দেয়, যার ফলে পুনরাবৃত্তি ভিজিট করার সময় দ্রুত পৃষ্ঠা লোড হয়। যাইহোক, ছোট ফাইলগুলি বড় ফাইলের তুলনায় কমপ্রেশন থেকে কম উপকৃত হয় এবং একটি আনপ্রাইমড ব্রাউজার ক্যাশের সাথে পৃষ্ঠা লোড হওয়ার সময় নেটওয়ার্ক রাউন্ড-ট্রিপ সময় বাড়াতে পারে। ক্যাশিং দক্ষতা, কম্প্রেশন কার্যকারিতা এবং স্ক্রিপ্ট মূল্যায়ন সময়ের মধ্যে ভারসাম্য বজায় রাখার জন্য যত্ন নেওয়া আবশ্যক।
ওয়েবপ্যাক ডেমো
ওয়েবপ্যাক SplitChunksPlugin
ডেমো ।
আপনার জ্ঞান পরীক্ষা করুন
কোড স্প্লিটিং করার সময় কোন ধরনের import
স্টেটমেন্ট ব্যবহার করা হয়?
import
।import()
। কোন ধরনের import
বিবৃতি অবশ্যই জাভাস্ক্রিপ্ট মডিউলের শীর্ষে থাকতে হবে এবং অন্য কোন স্থানে থাকবে না?
import
।import()
। ওয়েবপ্যাকে SplitChunksPlugin
ব্যবহার করার সময়, একটি async
খণ্ড এবং একটি initial
খণ্ডের মধ্যে পার্থক্য কী?
async
খণ্ডগুলি স্ট্যাটিক import
ব্যবহার করে লোড করা হয় এবং initial
খণ্ডগুলি ডায়নামিক import()
ব্যবহার করে লোড করা হয়।async
খণ্ডগুলি dynamic import()
ব্যবহার করে লোড করা হয় এবং initial
খণ্ডগুলি স্ট্যাটিক import
ব্যবহার করে লোড করা হয়। পরবর্তী: অলস লোড চিত্র এবং <iframe>
উপাদান
যদিও এটি একটি মোটামুটি ব্যয়বহুল ধরণের সংস্থান হতে থাকে, জাভাস্ক্রিপ্টই একমাত্র রিসোর্স টাইপ নয় যা আপনি লোড করা পিছিয়ে দিতে পারেন। ছবি এবং <iframe>
উপাদানগুলি তাদের নিজস্বভাবে সম্ভাব্য ব্যয়বহুল সম্পদ। জাভাস্ক্রিপ্টের মতো, আপনি অলসভাবে লোড করে ছবি এবং <iframe>
উপাদানের লোডিং পিছিয়ে দিতে পারেন, যা এই কোর্সের পরবর্তী মডিউলে ব্যাখ্যা করা হয়েছে।