1. ভূমিকা
স্পেকুলেশন রুলস এপিআই ব্যবহার করে প্রিরেন্ডারিংয়ের মাধ্যমে তাৎক্ষণিক নেভিগেশন কীভাবে অর্জন করা যায় তা শেখার জন্য একটি ইন্টারেক্টিভ ডেমো এবং কোডল্যাব।
কোডল্যাবটি সম্পূর্ণ হতে 30 মিনিট সময় লাগবে বলে অনুমান করা হচ্ছে এবং আপনি স্ক্রিনের শীর্ষে অবশিষ্ট সময় ট্র্যাক করতে পারবেন।
পূর্বশর্ত
- নতুনদের জন্য HTML এবং জাভাস্ক্রিপ্ট সম্পর্কে জ্ঞান।
তুমি যা শিখো
- কিভাবে একটি ওয়েবসাইটে অনুমানমূলক লোডিং যোগ করবেন।
- Chrome DevTools ব্যবহার করে কীভাবে অনুমান সংক্রান্ত সমস্যাগুলি ডিবাগ করবেন।
তোমার যা দরকার
- Chrome 123 বা তার পরবর্তী সংস্করণ।
- ওয়েবসাইট চালানো বা প্রকাশ করার ক্ষমতা (উদাহরণস্বরূপ Glitch ব্যবহার করা হয়েছে, তবে অনুরূপ যেকোনো পরিষেবা বা স্থানীয়ভাবে চালিত ওয়েব সার্ভার এটি করবে)।
প্রস্তুত? তাহলে শুরু করা যাক!
2. আপনার পরিবেশ সেট আপ করুন
এই ডেমোতে আপনার প্রথম ধাপ হল গ্লিচে ৩ পৃষ্ঠার একটি পরীক্ষামূলক সাইট তৈরি করা:
- পৃষ্ঠা ১ হল হোম পেজ, পৃষ্ঠা ২ এবং পৃষ্ঠা ৩ এর লিঙ্ক সহ।
- পৃষ্ঠা ২- তে একটি ব্লকিং স্ক্রিপ্ট ব্যবহার করা হয়েছে যাতে পৃষ্ঠাটি ধীর গতিতে লোড হচ্ছে। পৃষ্ঠার লোডিং সময়ের পরিমাপ হিসেবে আপনি কনসোলে লার্জেস্ট কন্টেন্টফুল পেইন্ট (LCP) সময়ও লগ করবেন।
- পৃষ্ঠা ৩ হল পৃষ্ঠা ২ এর প্রায় কপি, কিন্তু এবার একটি ইমেজ LCP সহ, তাই ডেমোতে দুটি লিঙ্ক থাকবে।
যদি আপনার নিজস্ব ডেমো সাইট থাকে যেখানে আপনি কাজ করতে চান, তাহলে সেই বিষয়ে সমতুল্য পদক্ষেপগুলি করতে দ্বিধা করবেন না।
গ্লিচ ব্যবহার করার জন্য, আপনার একটি গ্লিচ অ্যাকাউন্ট থাকতে হবে। আপনি স্থানীয় ডেভেলপমেন্ট সার্ভার থেকেও এই পৃষ্ঠাগুলি পরিবেশন করতে পারেন, অথবা যদি আপনি এটি কীভাবে করবেন তার সাথে পরিচিত হন তবে অন্য প্ল্যাটফর্ম/পরিষেবা ব্যবহার করতে পারেন (সেই বিকল্পগুলি এখানে কভার করা হয়নি)।
গ্লিচ বেসিক ওয়েবসাইটটি রিমিক্স করে ওয়েবসাইটটি তৈরি করুন।
এটি আপনাকে মৌলিক সাইটটি দেবে:

গ্লিচ আপনার প্রোজেক্টকে একটি এলোমেলো নাম দেয় (এই উদাহরণে open-chalk-asparagus.glitch.me ), এবং আপনি glitch.me তে সাবডোমেইন হিসেবে প্রোজেক্টের নামে সেই প্রোজেক্টটি দেখতে পারেন। এই উদাহরণে, এটি https://open-chalk-asparagus.glitch.me/ তে রয়েছে।
আপনি বাম দিকের তালিকা থেকে নতুন ফাইল নির্বাচন এবং যোগ করতে পারেন, এবং ডানদিকের বিষয়বস্তু সম্পাদনা করতে পারেন। নীচের প্রিভিউ বোতামে ক্লিক করলে আপনি পাশের ফলকে অথবা নতুন উইন্ডোতে প্রিভিউ দেখতে পারবেন।
এখন আপনার পরিবেশ সেট আপ করা হয়েছে, এবং আপনার ডেমো সাইট সেট আপ করার জন্য পরবর্তী ধাপে যেতে পারেন।
৩. ডেমো সাইট তৈরি করুন
index.html ফাইলের কন্টেন্টগুলো প্রতিস্থাপন করে একটি বেসিক পেজ তৈরি করুন কয়েকটি লিঙ্ক দিয়ে:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🚀</text></svg>">
<title>Instant Loading Demo!</title>
</head>
<body>
<h1>Instant Loading Demo!</h1>
<p>This is a demo of the Speculation Rules API.</p>
<ul>
<li><a href="./page2.html">Page 2</a></li>
<li><a href="./page3.html">Page 3</a></li>
</ul>
</body>
</html>
আপনার গ্লিচের page2.html পৃষ্ঠাটি তৈরি করুন, বাম দিকের Files + বোতামে ক্লিক করে, page2.html টাইপ করে এবং Add this file এ ক্লিক করে।
নিম্নলিখিত কন্টেন্টটি কপি করে page2.html এ পেস্ট করুন:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🚀</text></svg>">
<title>Page 2</title>
<!-- Load script as a classic script to allow it to be blocking -->
<script src="./script.js"></script>
</head>
<body>
<h1>This is page 2</h1>
<h2>This is a demo of the Speculation Rules API.</h2>
<button onclick="history.back();">Go back</button>
</body>
</html>
এবং নিম্নলিখিত বিষয়বস্তু সহ একটি page3.html (এটি প্রায় পৃষ্ঠা 2 এর মতো, তবে আমরা এতে একটি ছবি যুক্ত করেছি):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🚀</text></svg>">
<title>Page 3</title>
<!-- Load script as a classic script to allow it to be blocking -->
<script src="./script.js"></script>
</head>
<body>
<h1>This is page 3</h1>
<p>This is a demo of the Speculation Rules API.</p>
<button onclick="history.back();">Go back</button>
<img src="./image.svg" alt="LCP image">
</body>
</html>
পৃষ্ঠা ৩ একটি image.svg ফাইলকে বোঝায়, তাই আসুন নিম্নলিখিত বিষয়বস্তু দিয়ে এটি তৈরি করি:
<svg xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0.0 0.0 384.0 288.0" fill="none" stroke="none" stroke-linecap="square" stroke-miterlimit="10"><clipPath id="p.0"><path d="m0 0l384.0 0l0 288.0l-384.0 0l0 -288.0z" clip-rule="nonzero"/></clipPath><g clip-path="url(#p.0)"><path fill="#000000" fill-opacity="0.0" d="m0 0l384.0 0l0 288.0l-384.0 0z" fill-rule="evenodd"/><path fill="#000000" fill-opacity="0.0" d="m47.99836 24.0l288.0 0l0 96.0l-288.0 0z" fill-rule="evenodd"/><path fill="#2979ff" d="m115.79305 40.46437l11.875 0l0 51.75l26.671867 0l0 11.265625l-38.546867 0l0 -63.015625zm76.99615 64.421875q-9.15625 0 -16.71875 -4.34375q-7.5625 -4.359375 -11.921875 -11.890625q-4.359375 -7.53125 -4.359375 -16.671875q0 -9.15625 4.359375 -16.671875q4.359375 -7.53125 11.921875 -11.890625q7.5625 -4.359375 16.71875 -4.359375q14.25 0 23.578125 10.296875l-8.359375 8.09375q-6.0625 -7.125 -15.125 -7.125q-5.90625 0 -10.75 2.6875q-4.828125 2.6875 -7.609375 7.625q-2.765625 4.921875 -2.765625 11.34375q0 6.421875 2.765625 11.359375q2.78125 4.921875 7.609375 7.609375q4.84375 2.671875 10.75 2.671875q9.9375 0 16.625 -8.265625l8.453125 8.0q-4.671875 5.640625 -11.046875 8.59375q-6.375 2.9375 -14.125 2.9375zm36.17192 -64.421875l22.171875 0q5.984375 0 10.90625 2.515625q4.9375 2.515625 7.75 7.046875q2.8125 4.53125 2.8125 10.328125q0 5.8125 -2.8125 10.390625q-2.8125 4.578125 -7.75 7.09375q-4.921875 2.5 -10.90625 2.5l-10.296875 0l0 23.140625l-11.875 0l0 -63.015625zm22.53125 28.609375q4.390625 0 6.890625 -2.546875q2.515625 -2.5625 2.515625 -6.171875q0 -3.609375 -2.515625 -6.109375q-2.5 -2.515625 -6.890625 -2.515625l-10.65625 0l0 17.34375l10.65625 0z" fill-rule="nonzero"/><path fill="#0cce6b" d="m43.2 177.60136l96.0 0l0 38.393692l-96.0 0z" fill-rule="evenodd"/><path fill="#000000" d="m77.08874 201.5057q-1.234375 0 -2.265625 -0.578125q-1.03125 -0.59375 -1.640625 -1.609375q-0.59375 -1.03125 -0.59375 -2.296875q0 -1.265625 0.59375 -2.28125q0.609375 -1.03125 1.640625 -1.609375q1.03125 -0.59375 2.265625 -0.59375q0.984375 0 1.8125 0.34375q0.828125 0.34375 1.390625 0.96875l-0.90625 0.921875q-0.875 -0.984375 -2.296875 -0.984375q-0.84375 0 -1.578125 0.40625q-0.734375 0.390625 -1.171875 1.140625q-0.421875 0.734375 -0.421875 1.6875q0 0.953125 0.4375 1.703125q0.4375 0.734375 1.15625 1.140625q0.734375 0.390625 1.578125 0.390625q1.359375 0 2.21875 -0.84375q0.265625 -0.265625 0.453125 -0.671875q0.1875 -0.40625 0.265625 -0.90625l-2.953125 0l0 -1.15625l4.171875 0q0.078125 0.40625 0.078125 0.6875q0 0.828125 -0.265625 1.5625q-0.25 0.734375 -0.796875 1.296875q-0.578125 0.625 -1.390625 0.953125q-0.796875 0.328125 -1.78125 0.328125zm9.765564 0q-1.234375 0 -2.265625 -0.59375q-1.015625 -0.609375 -1.59375 -1.625q-0.578125 -1.03125 -0.578125 -2.265625q0 -1.234375 0.578125 -2.25q0.578125 -1.03125 1.59375 -1.625q1.03125 -0.609375 2.265625 -0.609375q1.25 0 2.265625 0.609375q1.015625 0.59375 1.59375 1.625q0.59375 1.015625 0.59375 2.25q0 1.234375 -0.59375 2.265625q-0.578125 1.015625 -1.59375 1.625q-1.015625 0.59375 -2.265625 0.59375zm0 -1.25q0.875 0 1.578125 -0.40625q0.71875 -0.421875 1.125 -1.15625q0.421875 -0.734375 0.421875 -1.671875q0 -0.9375 -0.421875 -1.671875q-0.40625 -0.734375 -1.125 -1.140625q-0.703125 -0.421875 -1.578125 -0.421875q-0.859375 0 -1.578125 0.421875q-0.703125 0.40625 -1.125 1.140625q-0.40625 0.734375 -0.40625 1.671875q0 0.9375 0.40625 1.671875q0.421875 0.734375 1.125 1.15625q0.71875 0.40625 1.578125 0.40625zm9.864075 1.25q-1.234375 0 -2.265625 -0.59375q-1.015625 -0.609375 -1.59375 -1.625q-0.578125 -1.03125 -0.578125 -2.265625q0 -1.234375 0.578125 -2.25q0.578125 -1.03125 1.59375 -1.625q1.03125 -0.609375 2.265625 -0.609375q1.25 0 2.265625 0.609375q1.015625 0.59375 1.59375 1.625q0.59375 1.015625 0.59375 2.25q0 1.234375 -0.59375 2.265625q-0.578125 1.015625 -1.59375 1.625q-1.015625 0.59375 -2.265625 0.59375zm0 -1.25q0.875 0 1.578125 -0.40625q0.71875 -0.421875 1.125 -1.15625q0.421875 -0.734375 0.421875 -1.671875q0 -0.9375 -0.421875 -1.671875q-0.40625 -0.734375 -1.125 -1.140625q-0.703125 -0.421875 -1.578125 -0.421875q-0.859375 0 -1.578125 0.421875q-0.703125 0.40625 -1.125 1.140625q-0.40625 0.734375 -0.40625 1.671875q0 0.9375 0.40625 1.671875q0.421875 0.734375 1.125 1.15625q0.71875 0.40625 1.578125 0.40625zm5.968445 -7.53125l2.75 0q1.328125 0 2.3125 0.546875q1.0 0.53125 1.53125 1.515625q0.53125 0.96875 0.53125 2.234375q0 1.265625 -0.53125 2.25q-0.53125 0.96875 -1.53125 1.515625q-0.984375 0.53125 -2.3125 0.53125l-2.75 0l0 -8.59375zm2.71875 7.34375q1.453125 0 2.265625 -0.8125q0.8125 -0.8125 0.8125 -2.234375q0 -1.421875 -0.8125 -2.234375q-0.8125 -0.8125 -2.265625 -0.8125l-1.390625 0l0 6.09375l1.390625 0z" fill-rule="nonzero"/><path fill="#ffa400" d="m139.2 177.60132l105.60631 0l0 38.393692l-105.60631 0z" fill-rule="evenodd"/><path fill="#000000" d="m173.98776 185.72441l1.5625 0l3.890625 6.3125l0.0625 0l-0.0625 -1.65625l0 -4.65625l1.3125 0l0 8.59375l-1.375 0l-4.078125 -6.640625l-0.078125 0l0.078125 1.65625l0 4.984375l-1.3125 0l0 -8.59375zm8.700058 0l5.21875 0l0 1.25l-3.890625 0l0 2.421875l3.5 0l0 1.25l-3.5 0l0 2.421875l3.890625 0l0 1.25l-5.21875 0l0 -8.59375zm6.864044 0l5.21875 0l0 1.25l-3.890625 0l0 2.421875l3.5 0l0 1.25l-3.5 0l0 2.421875l3.890625 0l0 1.25l-5.21875 0l0 -8.59375zm6.864044 0l2.75 0q1.328125 0 2.3125 0.546875q1.0 0.53125 1.53125 1.515625q0.53125 0.96875 0.53125 2.234375q0 1.265625 -0.53125 2.25q-0.53125 0.96875 -1.53125 1.515625q-0.984375 0.53125 -2.3125 0.53125l-2.75 0l0 -8.59375zm2.71875 7.34375q1.453125 0 2.265625 -0.8125q0.8125 -0.8125 0.8125 -2.234375q0 -1.421875 -0.8125 -2.234375q-0.8125 -0.8125 -2.265625 -0.8125l-1.390625 0l0 6.09375l1.390625 0zm8.42131 1.4375q-1.0625 0 -1.921875 -0.625q-0.84375 -0.625 -1.1875 -1.75l1.25 -0.5q0.1875 0.71875 0.671875 1.171875q0.5 0.453125 1.203125 0.453125q0.640625 0 1.09375 -0.328125q0.453125 -0.34375 0.453125 -0.921875q0 -0.546875 -0.40625 -0.890625q-0.390625 -0.359375 -1.359375 -0.703125l-0.546875 -0.1875q-0.875 -0.3125 -1.453125 -0.859375q-0.578125 -0.5625 -0.578125 -1.484375q0 -0.640625 0.34375 -1.171875q0.34375 -0.546875 0.953125 -0.859375q0.625 -0.3125 1.40625 -0.3125q1.109375 0 1.78125 0.546875q0.671875 0.546875 0.90625 1.21875l-1.1875 0.515625q-0.109375 -0.4375 -0.5 -0.75q-0.375 -0.3125 -1.0 -0.3125q-0.578125 0 -1.0 0.3125q-0.40625 0.3125 -0.40625 0.796875q0 0.4375 0.359375 0.734375q0.375 0.296875 1.140625 0.5625l0.5625 0.1875q1.09375 0.390625 1.6875 1.0q0.609375 0.609375 0.609375 1.625q0 0.84375 -0.421875 1.421875q-0.421875 0.5625 -1.09375 0.84375q-0.671875 0.265625 -1.359375 0.265625zm3.431305 -0.1875l0 0z" fill-rule="nonzero"/><path fill="#000000" d="m150.18561 199.72441l1.328125 0l0 8.59375l-1.328125 0l0 -8.59375zm3.2520294 0l1.78125 0l2.5 6.546875l0.078125 0l2.515625 -6.546875l1.78125 0l0 8.59375l-1.296875 0l0 -4.859375l0.078125 -1.53125l-0.078125 0l-2.515625 6.390625l-1.03125 0l-2.515625 -6.390625l-0.0625 0l0.0625 1.53125l0 4.859375l-1.296875 0l0 -8.59375zm10.596069 0l2.953125 0q0.765625 0 1.40625 0.34375q0.640625 0.328125 1.015625 0.9375q0.390625 0.59375 0.390625 1.34375q0 0.765625 -0.390625 1.359375q-0.375 0.59375 -1.015625 0.9375q-0.640625 0.328125 -1.40625 0.328125l-1.625 0l0 3.34375l-1.328125 0l0 -8.59375zm2.984375 4.015625q0.671875 0 1.0625 -0.40625q0.40625 -0.421875 0.40625 -0.984375q0 -0.546875 -0.40625 -0.953125q-0.390625 -0.421875 -1.0625 -0.421875l-1.65625 0l0 2.765625l1.65625 0zm4.131668 -4.015625l3.015625 0q0.78125 0 1.40625 0.34375q0.640625 0.328125 1.0 0.9375q0.359375 0.59375 0.359375 1.34375q0 0.875 -0.5625 1.546875q-0.546875 0.65625 -1.390625 0.875l-0.015625 0.0625l2.375 3.40625l0 0.078125l-1.53125 0l-2.28125 -3.375l-1.046875 0l0 3.375l-1.328125 0l0 -8.59375zm2.984375 4.015625q0.625 0 1.046875 -0.390625q0.421875 -0.40625 0.421875 -1.0q0 -0.5625 -0.390625 -0.96875q-0.390625 -0.421875 -1.03125 -0.421875l-1.703125 0l0 2.78125l1.65625 0zm8.351303 4.765625q-1.234375 0 -2.265625 -0.59375q-1.015625 -0.609375 -1.59375 -1.625q-0.578125 -1.03125 -0.578125 -2.265625q0 -1.234375 0.578125 -2.25q0.578125 -1.03125 1.59375 -1.625q1.03125 -0.609375 2.265625 -0.609375q1.25 0 2.265625 0.609375q1.015625 0.59375 1.59375 1.625q0.59375 1.015625 0.59375 2.25q0 1.234375 -0.59375 2.265625q-0.578125 1.015625 -1.59375 1.625q-1.015625 0.59375 -2.265625 0.59375zm0 -1.25q0.875 0 1.578125 -0.40625q0.71875 -0.421875 1.125 -1.15625q0.421875 -0.734375 0.421875 -1.671875q0 -0.9375 -0.421875 -1.671875q-0.40625 -0.734375 -1.125 -1.140625q-0.703125 -0.421875 -1.578125 -0.421875q-0.859375 0 -1.578125 0.421875q-0.703125 0.40625 -1.125 1.140625q-0.40625 0.734375 -0.40625 1.671875q0 0.9375 0.40625 1.671875q0.421875 0.734375 1.125 1.15625q0.71875 0.40625 1.578125 0.40625zm4.811569 -7.53125l1.4375 0l1.9375 5.71875l0.3125 0.96875l0.0625 0l0.328125 -0.96875l2.03125 -5.71875l1.4375 0l-3.140625 8.59375l-1.359375 0l-3.046875 -8.59375zm8.680923 0l5.21875 0l0 1.25l-3.890625 0l0 2.421875l3.5 0l0 1.25l-3.5 0l0 2.421875l3.890625 0l0 1.25l-5.21875 0l0 -8.59375zm6.864044 0l1.78125 0l2.5 6.546875l0.078125 0l2.515625 -6.546875l1.78125 0l0 8.59375l-1.296875 0l0 -4.859375l0.078125 -1.53125l-0.078125 0l-2.515625 6.390625l-1.03125 0l-2.515625 -6.390625l-0.0625 0l0.0625 1.53125l0 4.859375l-1.296875 0l0 -8.59375zm10.596069 0l5.21875 0l0 1.25l-3.890625 0l0 2.421875l3.5 0l0 1.25l-3.5 0l0 2.421875l3.890625 0l0 1.25l-5.21875 0l0 -8.59375zm6.864044 0l1.5625 0l3.890625 6.3125l0.0625 0l-0.0625 -1.65625l0 -4.65625l1.3125 0l0 8.59375l-1.375 0l-4.078125 -6.640625l-0.078125 0l0.078125 1.65625l0 4.984375l-1.3125 0l0 -8.59375zm10.450058 1.25l-2.40625 0l0 -1.25l6.125 0l0 1.25l-2.390625 0l0 7.34375l-1.328125 0l0 -7.34375z" fill-rule="nonzero"/><path fill="#ff4e42" d="m243.84 177.6l96.0 0l0 38.393692l-96.0 0z" fill-rule="evenodd"/><path fill="#000000" d="m275.72064 192.7231l2.953125 0q0.765625 0 1.40625 0.34375q0.640625 0.328125 1.015625 0.9375q0.390625 0.59375 0.390625 1.34375q0 0.765625 -0.390625 1.359375q-0.375 0.59375 -1.015625 0.9375q-0.640625 0.328125 -1.40625 0.328125l-1.625 0l0 3.34375l-1.328125 0l0 -8.59375zm2.984375 4.015625q0.671875 0 1.0625 -0.40625q0.40625 -0.421875 0.40625 -0.984375q0 -0.546875 -0.40625 -0.953125q-0.390625 -0.421875 -1.0625 -0.421875l-1.65625 0l0 2.765625l1.65625 0zm8.039276 4.765625q-1.234375 0 -2.265625 -0.59375q-1.015625 -0.609375 -1.59375 -1.625q-0.578125 -1.03125 -0.578125 -2.265625q0 -1.234375 0.578125 -2.25q0.578125 -1.03125 1.59375 -1.625q1.03125 -0.609375 2.265625 -0.609375q1.25 0 2.265625 0.609375q1.015625 0.59375 1.59375 1.625q0.59375 1.015625 0.59375 2.25q0 1.234375 -0.59375 2.265625q-0.578125 1.015625 -1.59375 1.625q-1.015625 0.59375 -2.265625 0.59375zm0 -1.25q0.875 0 1.578125 -0.40625q0.71875 -0.421875 1.125 -1.15625q0.421875 -0.734375 0.421875 -1.671875q0 -0.9375 -0.421875 -1.671875q-0.40625 -0.734375 -1.125 -1.140625q-0.703125 -0.421875 -1.578125 -0.421875q-0.859375 0 -1.578125 0.421875q-0.703125 0.40625 -1.125 1.140625q-0.40625 0.734375 -0.40625 1.671875q0 0.9375 0.40625 1.671875q0.421875 0.734375 1.125 1.15625q0.71875 0.40625 1.578125 0.40625zm9.864075 1.25q-1.234375 0 -2.265625 -0.59375q-1.015625 -0.609375 -1.59375 -1.625q-0.578125 -1.03125 -0.578125 -2.265625q0 -1.234375 0.578125 -2.25q0.578125 -1.03125 1.59375 -1.625q1.03125 -0.609375 2.265625 -0.609375q1.25 0 2.265625 0.609375q1.015625 0.59375 1.59375 1.625q0.59375 1.015625 0.59375 2.25q0 1.234375 -0.59375 2.265625q-0.578125 1.015625 -1.59375 1.625q-1.015625 0.59375 -2.265625 0.59375zm0 -1.25q0.875 0 1.578125 -0.40625q0.71875 -0.421875 1.125 -1.15625q0.421875 -0.734375 0.421875 -1.671875q0 -0.9375 -0.421875 -1.671875q-0.40625 -0.734375 -1.125 -1.140625q-0.703125 -0.421875 -1.578125 -0.421875q-0.859375 0 -1.578125 0.421875q-0.703125 0.40625 -1.125 1.140625q-0.40625 0.734375 -0.40625 1.671875q0 0.9375 0.40625 1.671875q0.421875 0.734375 1.125 1.15625q0.71875 0.40625 1.578125 0.40625zm5.968445 -7.53125l3.015625 0q0.78125 0 1.40625 0.34375q0.640625 0.328125 1.0 0.9375q0.359375 0.59375 0.359375 1.34375q0 0.875 -0.5625 1.546875q-0.546875 0.65625 -1.390625 0.875l-0.015625 0.0625l2.375 3.40625l0 0.078125l-1.53125 0l-2.28125 -3.375l-1.046875 0l0 3.375l-1.328125 0l0 -8.59375zm2.984375 4.015625q0.625 0 1.046875 -0.390625q0.421875 -0.40625 0.421875 -1.0q0 -0.5625 -0.390625 -0.96875q-0.390625 -0.421875 -1.03125 -0.421875l-1.703125 0l0 2.78125l1.65625 0z" fill-rule="nonzero"/><path fill="#000000" fill-opacity="0.0" d="m196.8 240.0l95.999985 0l0 28.409454l-95.999985 0z" fill-rule="evenodd"/><path fill="#434343" d="m223.49895 257.87723l-5.15625 0l0 -1.34375l5.015625 -7.40625l1.84375 0l0 7.140625l1.390625 0l0 1.609375l-1.390625 0l0 2.1875l-1.703125 0l0 -2.1875zm0 -1.609375l0 -4.609375l-0.09375 0l-3.125 4.609375l3.21875 0zm5.9627686 3.890625q-0.515625 0 -0.875 -0.34375q-0.34375 -0.359375 -0.34375 -0.859375q0 -0.484375 0.34375 -0.828125q0.359375 -0.359375 0.875 -0.359375q0.515625 0 0.859375 0.34375q0.34375 0.34375 0.34375 0.84375q0 0.5 -0.34375 0.859375q-0.34375 0.34375 -0.859375 0.34375zm7.3638763 0.15625q-1.34375 0 -2.359375 -0.75q-1.015625 -0.75 -1.578125 -2.046875q-0.546875 -1.3125 -0.546875 -2.921875q0 -1.625 0.546875 -2.921875q0.5625 -1.3125 1.578125 -2.0625q1.015625 -0.75 2.359375 -0.75q1.34375 0 2.359375 0.75q1.03125 0.75 1.578125 2.0625q0.5625 1.296875 0.5625 2.921875q0 1.609375 -0.5625 2.921875q-0.546875 1.296875 -1.578125 2.046875q-1.015625 0.75 -2.359375 0.75zm0 -1.625q0.84375 0 1.46875 -0.53125q0.625 -0.546875 0.953125 -1.46875q0.328125 -0.921875 0.328125 -2.09375q0 -1.171875 -0.328125 -2.109375q-0.328125 -0.9375 -0.953125 -1.453125q-0.625 -0.53125 -1.46875 -0.53125q-0.828125 0 -1.453125 0.53125q-0.609375 0.515625 -0.9375 1.453125q-0.328125 0.9375 -0.328125 2.109375q0 1.171875 0.328125 2.09375q0.328125 0.921875 0.9375 1.46875q0.625 0.53125 1.453125 0.53125zm5.294403 1.375l0 0zm7.712387 0.25q-1.390625 0 -2.296875 -0.59375q-0.90625 -0.609375 -1.265625 -1.59375l1.546875 -0.671875q0.28125 0.65625 0.8125 1.0q0.53125 0.34375 1.203125 0.34375q0.6875 0 1.140625 -0.25q0.46875 -0.25 0.46875 -0.734375q0 -0.453125 -0.390625 -0.71875q-0.390625 -0.265625 -1.21875 -0.453125l-0.96875 -0.21875q-0.984375 -0.25 -1.625 -0.859375q-0.640625 -0.609375 -0.640625 -1.53125q0 -0.703125 0.421875 -1.25q0.421875 -0.546875 1.140625 -0.84375q0.71875 -0.296875 1.5625 -0.296875q1.15625 0 2.0 0.453125q0.859375 0.453125 1.25 1.3125l-1.5 0.671875q-0.484375 -0.96875 -1.734375 -0.96875q-0.609375 0 -1.015625 0.25q-0.40625 0.25 -0.40625 0.640625q0 0.71875 1.25 1.03125l1.171875 0.296875q1.203125 0.296875 1.8125 0.90625q0.625 0.609375 0.625 1.515625q0 0.765625 -0.4375 1.34375q-0.4375 0.578125 -1.21875 0.90625q-0.765625 0.3125 -1.6875 0.3125zm8.654007 0q-1.1875 0 -2.140625 -0.546875q-0.95310974 -0.5625 -1.4843597 -1.546875q-0.53125 -0.984375 -0.53125 -2.21875q0 -1.171875 0.515625 -2.171875q0.515625 -1.0 1.4374847 -1.59375q0.9375 -0.59375 2.109375 -0.59375q1.234375 0 2.125 0.546875q0.890625 0.53125 1.359375 1.484375q0.484375 0.9375 0.484375 2.140625q0 0.3125 -0.03125 0.53125l-6.3125 0q0.125 1.171875 0.84375 1.8125q0.71875 0.625 1.671875 0.625q0.78125 0 1.34375 -0.359375q0.5625 -0.359375 0.90625 -0.953125l1.421875 0.6875q-0.5625 1.015625 -1.5 1.59375q-0.921875 0.5625 -2.21875 0.5625zm2.15625 -5.265625q-0.03125 -0.4375 -0.28125 -0.890625q-0.25 -0.453125 -0.75 -0.734375q-0.484375 -0.296875 -1.203125 -0.296875q-0.859375 0 -1.46875 0.53125q-0.59375 0.515625 -0.8125 1.390625l4.515625 0zm7.1706543 5.265625q-1.21875 0 -2.1875 -0.546875q-0.953125 -0.5625 -1.484375 -1.546875q-0.53125 -0.984375 -0.53125 -2.234375q0 -1.25 0.53125 -2.234375q0.53125 -0.984375 1.484375 -1.546875q0.96875 -0.5625 2.1875 -0.5625q1.34375 0 2.28125 0.609375q0.9375 0.59375 1.359375 1.65625l-1.578125 0.640625q-0.578125 -1.3125 -2.09375 -1.3125q-0.671875 0 -1.25 0.34375q-0.5625 0.34375 -0.890625 0.96875q-0.328125 0.625 -0.328125 1.4375q0 0.8125 0.328125 1.4375q0.328125 0.625 0.890625 0.96875q0.578125 0.34375 1.25 0.34375q0.765625 0 1.3125 -0.34375q0.5625 -0.34375 0.859375 -1.0l1.5625 0.671875q-0.484375 1.046875 -1.4375 1.65625q-0.9375 0.59375 -2.265625 0.59375z" fill-rule="nonzero"/><path fill="#000000" fill-opacity="0.0" d="m91.2 240.39362l96.0 0l0 28.409454l-96.0 0z" fill-rule="evenodd"/><path fill="#434343" d="m114.02157 258.83334q3.25 -3.234375 4.0 -4.078125q0.703125 -0.734375 0.953125 -1.1875q0.265625 -0.46875 0.265625 -1.09375q0 -0.640625 -0.484375 -1.109375q-0.484375 -0.46875 -1.328125 -0.46875q-0.765625 0 -1.234375 0.4375q-0.46875 0.4375 -0.65625 1.03125l-1.546875 -0.640625q0.15625 -0.578125 0.59375 -1.140625q0.453125 -0.5625 1.1875 -0.9375q0.734375 -0.390625 1.6875 -0.390625q1.046875 0 1.84375 0.4375q0.796875 0.421875 1.234375 1.15625q0.453125 0.71875 0.453125 1.578125q0 1.734375 -1.75 3.46875q-0.703125 0.703125 -1.578125 1.59375q-0.90625 0.875 -1.359375 1.359375l0.015625 0.046875l4.796875 0l0 1.5625l-7.09375 0l0 -1.625zm9.984146 1.71875q-0.515625 0 -0.875 -0.34375q-0.34375 -0.359375 -0.34375 -0.859375q0 -0.484375 0.34375 -0.828125q0.359375 -0.359375 0.875 -0.359375q0.515625 0 0.859375 0.34375q0.34375 0.34375 0.34375 0.84375q0 0.5 -0.34375 0.859375q-0.34375 0.34375 -0.859375 0.34375zm6.598259 0.15625q-0.8125 0 -1.59375 -0.328125q-0.78125 -0.328125 -1.3750076 -0.984375q-0.578125 -0.671875 -0.8125 -1.640625l1.5468826 -0.609375q0.234375 0.890625 0.796875 1.421875q0.5625 0.53125 1.421875 0.53125q0.90625 0 1.5 -0.578125q0.609375 -0.59375 0.609375 -1.5q0 -0.921875 -0.59375 -1.515625q-0.578125 -0.59375 -1.5 -0.59375q-0.53125 0 -0.984375 0.234375q-0.453125 0.21875 -0.75 0.625l-1.6875076 -0.75l0.65625 -5.5l5.9062576 0l0 1.5625l-4.484375 0l-0.421875 2.9375l0.09375 0.015625q0.875 -0.6875 2.0 -0.6875q0.9375 0 1.734375 0.46875q0.796875 0.46875 1.265625 1.296875q0.484375 0.828125 0.484375 1.890625q0 1.046875 -0.5 1.90625q-0.484375 0.84375 -1.359375 1.328125q-0.875 0.46875 -1.953125 0.46875zm4.684021 -0.25l0 0zm7.712387 0.25q-1.390625 0 -2.296875 -0.59375q-0.90625 -0.609375 -1.265625 -1.59375l1.546875 -0.671875q0.28125 0.65625 0.8125 1.0q0.53125 0.34375 1.203125 0.34375q0.6875 0 1.140625 -0.25q0.46875 -0.25 0.46875 -0.734375q0 -0.453125 -0.390625 -0.71875q-0.390625 -0.265625 -1.21875 -0.453125l-0.96875 -0.21875q-0.984375 -0.25 -1.625 -0.859375q-0.640625 -0.609375 -0.640625 -1.53125q0 -0.703125 0.421875 -1.25q0.421875 -0.546875 1.140625 -0.84375q0.71875 -0.296875 1.5625 -0.296875q1.15625 0 2.0 0.453125q0.859375 0.453125 1.25 1.3125l-1.5 0.671875q-0.484375 -0.96875 -1.734375 -0.96875q-0.609375 0 -1.015625 0.25q-0.40625 0.25 -0.40625 0.640625q0 0.71875 1.25 1.03125l1.171875 0.296875q1.203125 0.296875 1.8125 0.90625q0.625 0.609375 0.625 1.515625q0 0.765625 -0.4375 1.34375q-0.4375 0.578125 -1.21875 0.90625q-0.765625 0.3125 -1.6875 0.3125zm8.654022 0q-1.1875 0 -2.140625 -0.546875q-0.953125 -0.5625 -1.484375 -1.546875q-0.53125 -0.984375 -0.53125 -2.21875q0 -1.171875 0.515625 -2.171875q0.515625 -1.0 1.4375 -1.59375q0.9375 -0.59375 2.109375 -0.59375q1.234375 0 2.125 0.546875q0.890625 0.53125 1.359375 1.484375q0.484375 0.9375 0.484375 2.140625q0 0.3125 -0.03125 0.53125l-6.3125 0q0.125 1.171875 0.84375 1.8125q0.71875 0.625 1.671875 0.625q0.78125 0 1.34375 -0.359375q0.5625 -0.359375 0.90625 -0.953125l1.421875 0.6875q-0.5625 1.015625 -1.5 1.59375q-0.921875 0.5625 -2.21875 0.5625zm2.15625 -5.265625q-0.03125 -0.4375 -0.28125 -0.890625q-0.25 -0.453125 -0.75 -0.734375q-0.484375 -0.296875 -1.203125 -0.296875q-0.859375 0 -1.46875 0.53125q-0.59375 0.515625 -0.8125 1.390625l4.515625 0zm7.170639 5.265625q-1.21875 0 -2.1875 -0.546875q-0.953125 -0.5625 -1.484375 -1.546875q-0.53125 -0.984375 -0.53125 -2.234375q0 -1.25 0.53125 -2.234375q0.53125 -0.984375 1.484375 -1.546875q0.96875 -0.5625 2.1875 -0.5625q1.34375 0 2.28125 0.609375q0.9375 0.59375 1.359375 1.65625l-1.578125 0.640625q-0.578125 -1.3125 -2.09375 -1.3125q-0.671875 0 -1.25 0.34375q-0.5625 0.34375 -0.890625 0.96875q-0.328125 0.625 -0.328125 1.4375q0 0.8125 0.328125 1.4375q0.328125 0.625 0.890625 0.96875q0.578125 0.34375 1.25 0.34375q0.765625 0 1.3125 -0.34375q0.5625 -0.34375 0.859375 -1.0l1.5625 0.671875q-0.484375 1.046875 -1.4375 1.65625q-0.9375 0.59375 -2.265625 0.59375z" fill-rule="nonzero"/><path fill="#000000" fill-opacity="0.0" d="m139.2 241.87541l0 -28.56694" fill-rule="evenodd"/><path stroke="#434343" stroke-width="2.0" stroke-linejoin="round" stroke-linecap="butt" d="m139.2 241.87541l0 -20.986938" fill-rule="evenodd"/><path fill="#434343" stroke="#434343" stroke-width="2.0" stroke-linecap="butt" d="m139.2 214.30849c1.8170166 0 3.2899933 1.4729767 3.2899933 3.2899933c0 1.8170166 -1.4729767 3.2899933 -3.2899933 3.2899933c-1.8170166 0 -3.2899933 -1.4729767 -3.2899933 -3.2899933c0 -1.8170166 1.4729767 -3.2899933 3.2899933 -3.2899933z" fill-rule="nonzero"/><path fill="#000000" fill-opacity="0.0" d="m48.00492 115.2l288.0 0l0 28.7874l-288.0 0z" fill-rule="evenodd"/><path fill="#666666" d="m85.778755 122.4812l1.703125 0l0 12.6875l6.265625 0l0 1.625l-7.96875 0l0 -14.3125zm13.101868 14.625q-1.109375 0 -2.0 -0.4375q-0.875 -0.4375 -1.359375 -1.203125q-0.46875 -0.765625 -0.46875 -1.75q0 -1.625 1.21875 -2.53125q1.21875 -0.90625 3.078125 -0.90625q0.921875 0 1.703125 0.203125q0.796875 0.1875 1.21875 0.453125l0 -0.625q0 -1.140625 -0.8125 -1.828125q-0.796875 -0.6875 -2.015625 -0.6875q-0.84375 0 -1.578125 0.375q-0.71875 0.359375 -1.140625 1.03125l-1.28125 -0.96875q0.609375 -0.921875 1.65625 -1.4375q1.0625 -0.515625 2.34375 -0.515625q2.078125 0 3.25 1.09375q1.1875 1.078125 1.1875 2.96875l0 6.453125l-1.609375 0l0 -1.453125l-0.09375 0q-0.4375 0.734375 -1.3125 1.25q-0.875 0.515625 -1.984375 0.515625zm0.171875 -1.5q0.859375 0 1.59375 -0.4375q0.734375 -0.4375 1.171875 -1.171875q0.453125 -0.75 0.453125 -1.625q-0.484375 -0.3125 -1.1875 -0.515625q-0.703125 -0.203125 -1.484375 -0.203125q-1.390625 0 -2.109375 0.578125q-0.703125 0.578125 -0.703125 1.5q0 0.84375 0.640625 1.359375q0.640625 0.515625 1.625 0.515625zm7.19812 -9.015625l1.609375 0l0 1.640625l0.078125 0q0.3125 -0.84375 1.171875 -1.390625q0.859375 -0.546875 1.796875 -0.546875q0.703125 0 1.203125 0.203125l0 1.84375q-0.640625 -0.328125 -1.4375 -0.328125q-0.75 0 -1.375 0.421875q-0.609375 0.421875 -0.984375 1.140625q-0.375 0.703125 -0.375 1.515625l0 5.703125l-1.6875 0l0 -10.203125zm11.46875 14.84375q-1.796875 0 -2.96875 -0.84375q-1.171875 -0.84375 -1.5625 -2.015625l1.5625 -0.65625q0.3125 0.875 1.09375 1.421875q0.796875 0.546875 1.875 0.546875q1.578125 0 2.453125 -0.921875q0.875 -0.90625 0.875 -2.59375l0 -1.140625l-0.078125 0q-0.5 0.78125 -1.421875 1.28125q-0.90625 0.484375 -2.0625 0.484375q-1.3125 0 -2.40625 -0.671875q-1.09375 -0.6875 -1.734375 -1.90625q-0.640625 -1.21875 -0.640625 -2.78125q0 -1.546875 0.640625 -2.765625q0.640625 -1.234375 1.734375 -1.90625q1.09375 -0.6875 2.40625 -0.6875q1.15625 0 2.0625 0.484375q0.921875 0.484375 1.421875 1.296875l0.078125 0l0 -1.46875l1.625 0l0 9.796875q0 2.46875 -1.375 3.75q-1.359375 1.296875 -3.578125 1.296875zm0 -5.984375q0.921875 0 1.671875 -0.453125q0.75 -0.46875 1.203125 -1.328125q0.453125 -0.859375 0.453125 -2.03125q0 -1.203125 -0.453125 -2.0625q-0.453125 -0.859375 -1.203125 -1.3125q-0.75 -0.453125 -1.671875 -0.453125q-0.921875 0 -1.6875 0.46875q-0.75 0.453125 -1.203125 1.3125q-0.4375 0.859375 -0.4375 2.046875q0 1.171875 0.4375 2.046875q0.453125 0.875 1.203125 1.328125q0.765625 0.4375 1.6875 0.4375zm11.902489 1.65625q-1.453125 0 -2.6250076 -0.6875q-1.15625 -0.703125 -1.8125 -1.9375q-0.640625 -1.234375 -0.640625 -2.765625q0 -1.46875 0.609375 -2.71875q0.609375 -1.25 1.734375 -1.984375q1.1406326 -0.734375 2.5937576 -0.734375q1.5 0 2.59375 0.671875q1.109375 0.65625 1.703125 1.84375q0.59375 1.1875 0.59375 2.703125q0 0.234375 -0.046875 0.515625l-8.078133 0q0.0625 1.15625 0.5625 1.96875q0.5 0.796875 1.2656326 1.203125q0.765625 0.390625 1.609375 0.390625q2.0 0 3.015625 -1.84375l1.4375 0.703125q-0.625 1.21875 -1.765625 1.953125q-1.140625 0.71875 -2.75 0.71875zm2.9375 -6.5q-0.03125 -0.625 -0.359375 -1.265625q-0.3125 -0.640625 -1.0 -1.078125q-0.671875 -0.453125 -1.71875 -0.453125q-1.203125 0 -2.0468826 0.78125q-0.828125 0.765625 -1.09375 2.015625l6.2187576 0zm7.4381256 6.5q-1.625 0 -2.734375 -0.765625q-1.09375 -0.765625 -1.5625 -1.96875l1.53125 -0.671875q0.375 0.90625 1.125 1.40625q0.75 0.5 1.640625 0.5q0.96875 0 1.640625 -0.375q0.6875 -0.390625 0.6875 -1.125q0 -0.625 -0.546875 -1.015625q-0.53125 -0.390625 -1.6875 -0.671875l-1.25 -0.328125q-1.21875 -0.296875 -2.0 -1.015625q-0.78125 -0.71875 -0.78125 -1.859375q0 -0.875 0.53125 -1.546875q0.53125 -0.671875 1.40625 -1.03125q0.890625 -0.359375 1.90625 -0.359375q1.34375 0 2.390625 0.578125q1.046875 0.578125 1.484375 1.625l-1.46875 0.671875q-0.6875 -1.359375 -2.421875 -1.359375q-0.84375 0 -1.484375 0.390625q-0.625 0.390625 -0.625 0.984375q0 0.5625 0.4375 0.921875q0.453125 0.34375 1.328125 0.5625l1.484375 0.375q1.5 0.390625 2.25 1.140625q0.765625 0.75 0.765625 1.828125q0 0.9375 -0.546875 1.65625q-0.53125 0.703125 -1.453125 1.078125q-0.921875 0.375 -2.046875 0.375zm9.734985 -0.15625q-0.625 0 -1.15625 -0.1875q-0.53125 -0.203125 -0.890625 -0.546875q-0.796875 -0.765625 -0.796875 -2.109375l0 -5.96875l-1.78125 0l0 -1.546875l1.78125 0l0 -2.875l1.703125 0l0 2.875l2.5 0l0 1.546875l-2.5 0l0 5.5625q0 0.828125 0.3125 1.234375q0.375 0.4375 1.09375 0.4375q0.625 0 1.125 -0.34375l0 1.671875q-0.296875 0.140625 -0.609375 0.1875q-0.3125 0.0625 -0.78125 0.0625zm2.132492 -0.15625l0 0zm12.5525055 0.3125q-2.078125 0 -3.78125 -0.96875q-1.6875 -0.984375 -2.65625 -2.6875q-0.96875 -1.71875 -0.96875 -3.8125q0 -2.109375 0.96875 -3.8125q0.96875 -1.71875 2.65625 -2.6875q1.703125 -0.984375 3.78125 -0.984375q1.609375 0 2.9375 0.609375q1.328125 0.59375 2.3125 1.734375l-1.21875 1.171875q-0.828125 -0.96875 -1.796875 -1.421875q-0.96875 -0.46875 -2.234375 -0.46875q-1.546875 0 -2.859375 0.734375q-1.296875 0.71875 -2.0625 2.046875q-0.765625 1.328125 -0.765625 3.078125q0 1.734375 0.765625 3.0625q0.765625 1.328125 2.0625 2.0625q1.3125 0.734375 2.859375 0.734375q2.609375 0 4.421875 -2.140625l1.25 1.203125q-0.984375 1.171875 -2.453125 1.859375q-1.46875 0.6875 -3.21875 0.6875zm12.060623 0q-1.5 0 -2.703125 -0.71875q-1.1875 -0.71875 -1.859375 -1.953125q-0.671875 -1.234375 -0.671875 -2.734375q0 -1.5 0.671875 -2.734375q0.671875 -1.25 1.859375 -1.96875q1.203125 -0.71875 2.703125 -0.71875q1.5 0 2.703125 0.71875q1.203125 0.71875 1.875 1.96875q0.671875 1.234375 0.671875 2.734375q0 1.5 -0.671875 2.734375q-0.671875 1.234375 -1.875 1.953125q-1.203125 0.71875 -2.703125 0.71875zm0 -1.53125q0.953125 0 1.75 -0.46875q0.8125 -0.46875 1.296875 -1.34375q0.5 -0.890625 0.5 -2.0625q0 -1.1875 -0.5 -2.0625q-0.484375 -0.890625 -1.296875 -1.359375q-0.796875 -0.46875 -1.75 -0.46875q-0.9375 0 -1.765625 0.46875q-0.8125 0.46875 -1.296875 1.359375q-0.484375 0.875 -0.484375 2.0625q0 1.171875 0.484375 2.0625q0.484375 0.875 1.296875 1.34375q0.828125 0.46875 1.765625 0.46875zm7.032486 -8.984375l1.609375 0l0 1.5l0.078125 0q0.421875 -0.75 1.34375 -1.28125q0.921875 -0.53125 1.96875 -0.53125q1.828125 0 2.796875 1.078125q0.984375 1.0625 0.984375 2.890625l0 6.546875l-1.703125 0l0 -6.28125q0 -1.421875 -0.6875 -2.0625q-0.671875 -0.640625 -1.859375 -0.640625q-0.8125 0 -1.46875 0.46875q-0.640625 0.453125 -1.015625 1.203125q-0.359375 0.75 -0.359375 1.578125l0 5.734375l-1.6875 0l0 -10.203125zm14.641861 10.359375q-0.625 0 -1.15625 -0.1875q-0.53125 -0.203125 -0.890625 -0.546875q-0.796875 -0.765625 -0.796875 -2.109375l0 -5.96875l-1.78125 0l0 -1.546875l1.78125 0l0 -2.875l1.703125 0l0 2.875l2.5 0l0 1.546875l-2.5 0l0 5.5625q0 0.828125 0.3125 1.234375q0.375 0.4375 1.09375 0.4375q0.625 0 1.125 -0.34375l0 1.671875q-0.296875 0.140625 -0.609375 0.1875q-0.3125 0.0625 -0.78125 0.0625zm7.4893646 0.15625q-1.453125 0 -2.625 -0.6875q-1.15625 -0.703125 -1.8125 -1.9375q-0.640625 -1.234375 -0.640625 -2.765625q0 -1.46875 0.609375 -2.71875q0.609375 -1.25 1.734375 -1.984375q1.140625 -0.734375 2.59375 -0.734375q1.5 0 2.59375 0.671875q1.109375 0.65625 1.703125 1.84375q0.59375 1.1875 0.59375 2.703125q0 0.234375 -0.046875 0.515625l-8.078125 0q0.0625 1.15625 0.5625 1.96875q0.5 0.796875 1.265625 1.203125q0.765625 0.390625 1.609375 0.390625q2.0 0 3.015625 -1.84375l1.4375 0.703125q-0.625 1.21875 -1.765625 1.953125q-1.140625 0.71875 -2.75 0.71875zm2.9375 -6.5q-0.03125 -0.625 -0.359375 -1.265625q-0.3125 -0.640625 -1.0 -1.078125q-0.671875 -0.453125 -1.71875 -0.453125q-1.203125 0 -2.046875 0.78125q-0.828125 0.765625 -1.09375 2.015625l6.21875 0zm3.7912445 -4.015625l1.609375 0l0 1.5l0.078125 0q0.421875 -0.75 1.34375 -1.28125q0.921875 -0.53125 1.96875 -0.53125q1.828125 0 2.796875 1.078125q0.984375 1.0625 0.984375 2.890625l0 6.546875l-1.703125 0l0 -6.28125q0 -1.421875 -0.6875 -2.0625q-0.671875 -0.640625 -1.859375 -0.640625q-0.8125 0 -1.46875 0.46875q-0.640625 0.453125 -1.015625 1.203125q-0.359375 0.75 -0.359375 1.578125l0 5.734375l-1.6875 0l0 -10.203125zm14.641861 10.359375q-0.625 0 -1.15625 -0.1875q-0.53125 -0.203125 -0.890625 -0.546875q-0.796875 -0.765625 -0.796875 -2.109375l0 -5.96875l-1.78125 0l0 -1.546875l1.78125 0l0 -2.875l1.703125 0l0 2.875l4.640625 0l0 -1.09375q0 -0.96875 0.421875 -1.6875q0.4375 -0.71875 1.1875 -1.109375q0.75 -0.390625 1.640625 -0.390625q0.828125 0 1.5 0.25l0 1.65625q-0.390625 -0.15625 -0.703125 -0.234375q-0.3125 -0.09375 -0.75 -0.09375q-0.671875 0 -1.15625 0.484375q-0.46875 0.46875 -0.46875 1.296875l0 0.921875l2.625 0l0 1.546875l-2.625 0l0 8.65625l-1.671875 0l0 -8.65625l-4.640625 0l0 5.5625q0 0.828125 0.3125 1.234375q0.375 0.4375 1.09375 0.4375q0.625 0 1.125 -0.34375l0 1.671875q-0.296875 0.140625 -0.609375 0.1875q-0.3125 0.0625 -0.78125 0.0625zm13.38562 0.15625q-1.828125 0 -2.796875 -1.078125q-0.96875 -1.078125 -0.96875 -3.015625l0 -6.421875l1.6875 0l0 6.15625q0 1.46875 0.65625 2.15625q0.671875 0.671875 1.78125 0.671875q0.875 0 1.53125 -0.453125q0.671875 -0.46875 1.046875 -1.203125q0.375 -0.75 0.375 -1.5625l0 -5.765625l1.6875 0l0 10.203125l-1.609375 0l0 -1.484375l-0.078125 0q-0.421875 0.765625 -1.34375 1.28125q-0.921875 0.515625 -1.96875 0.515625zm7.532486 -14.625l1.6875 0l0 14.3125l-1.6875 0l0 -14.3125zm2.9543762 14.3125l0 0zm6.233734 -14.3125l4.828125 0q1.203125 0 2.21875 0.546875q1.015625 0.53125 1.625 1.5q0.609375 0.96875 0.609375 2.1875q0 1.21875 -0.609375 2.1875q-0.609375 0.96875 -1.625 1.515625q-1.015625 0.53125 -2.21875 0.53125l-3.125 0l0 5.84375l-1.703125 0l0 -14.3125zm4.859375 6.859375q0.8125 0 1.421875 -0.375q0.609375 -0.390625 0.9375 -0.984375q0.34375 -0.609375 0.34375 -1.265625q0 -0.65625 -0.34375 -1.25q-0.328125 -0.609375 -0.9375 -0.984375q-0.609375 -0.390625 -1.421875 -0.390625l-3.15625 0l0 5.25l3.15625 0zm9.182495 7.765625q-1.109375 0 -2.0 -0.4375q-0.875 -0.4375 -1.359375 -1.203125q-0.46875 -0.765625 -0.46875 -1.75q0 -1.625 1.21875 -2.53125q1.21875 -0.90625 3.078125 -0.90625q0.921875 0 1.703125 0.203125q0.796875 0.1875 1.21875 0.453125l0 -0.625q0 -1.140625 -0.8125 -1.828125q-0.796875 -0.6875 -2.015625 -0.6875q-0.84375 0 -1.578125 0.375q-0.71875 0.359375 -1.140625 1.03125l-1.28125 -0.96875q0.609375 -0.921875 1.65625 -1.4375q1.0625 -0.515625 2.34375 -0.515625q2.078125 0 3.25 1.09375q1.1875 1.078125 1.1875 2.96875l0 6.453125l-1.609375 0l0 -1.453125l-0.09375 0q-0.4375 0.734375 -1.3125 1.25q-0.875 0.515625 -1.984375 0.515625zm0.171875 -1.5q0.859375 0 1.59375 -0.4375q0.734375 -0.4375 1.171875 -1.171875q0.453125 -0.75 0.453125 -1.625q-0.484375 -0.3125 -1.1875 -0.515625q-0.703125 -0.203125 -1.484375 -0.203125q-1.390625 0 -2.109375 0.578125q-0.703125 0.578125 -0.703125 1.5q0 0.84375 0.640625 1.359375q0.640625 0.515625 1.625 0.515625zm8.19812 -10.890625q-0.5 0 -0.859375 -0.359375q-0.359375 -0.359375 -0.359375 -0.859375q0 -0.515625 0.359375 -0.859375q0.359375 -0.359375 0.859375 -0.359375q0.515625 0 0.859375 0.359375q0.359375 0.34375 0.359375 0.859375q0 0.5 -0.359375 0.859375q-0.34375 0.359375 -0.859375 0.359375zm-0.84375 1.875l1.703125 0l0 10.203125l-1.703125 0l0 -10.203125zm4.363739 0l1.609375 0l0 1.5l0.078125 0q0.421875 -0.75 1.34375 -1.28125q0.921875 -0.53125 1.96875 -0.53125q1.828125 0 2.796875 1.078125q0.984375 1.0625 0.984375 2.890625l0 6.546875l-1.703125 0l0 -6.28125q0 -1.421875 -0.6875 -2.0625q-0.671875 -0.640625 -1.859375 -0.640625q-0.8125 0 -1.46875 0.46875q-0.640625 0.453125 -1.015625 1.203125q-0.359375 0.75 -0.359375 1.578125l0 5.734375l-1.6875 0l0 -10.203125zm14.641876 10.359375q-0.625 0 -1.15625 -0.1875q-0.53125 -0.203125 -0.890625 -0.546875q-0.796875 -0.765625 -0.796875 -2.109375l0 -5.96875l-1.78125 0l0 -1.546875l1.78125 0l0 -2.875l1.703125 0l0 2.875l2.5 0l0 1.546875l-2.5 0l0 5.5625q0 0.828125 0.3125 1.234375q0.375 0.4375 1.09375 0.4375q0.625 0 1.125 -0.34375l0 1.671875q-0.296875 0.140625 -0.609375 0.1875q-0.3125 0.0625 -0.78125 0.0625z" fill-rule="nonzero"/><path fill="#000000" fill-opacity="0.0" d="m244.8 241.37184l0 -28.283463" fill-rule="evenodd"/><path stroke="#434343" stroke-width="2.0" stroke-linejoin="round" stroke-linecap="butt" d="m244.79999 241.37184l0 -20.703476" fill-rule="evenodd"/><path fill="#434343" stroke="#434343" stroke-width="2.0" stroke-linecap="butt" d="m244.79999 214.08838c1.8170166 0 3.2900085 1.4729767 3.2900085 3.2899933c0 1.8170166 -1.472992 3.2900085 -3.2900085 3.2900085c-1.8170166 0 -3.2899933 -1.472992 -3.2899933 -3.2900085c0 -1.8170166 1.4729767 -3.2899933 3.2899933 -3.2899933z" fill-rule="nonzero"/></g></svg>
উভয় পৃষ্ঠাই একটি script.js রিসোর্স লোড করে, যা ডিফল্টরূপে Glitch দ্বারা তৈরি করা হয়, তাই সেই ফাইলের বিষয়বস্তু নিম্নলিখিত দিয়ে প্রতিস্থাপন করুন:
function blockPause(milliseconds) {
const start = performance.now();
let lastCheck = start;
let lastTime = 0;
// Synchronous blocking is NOT best practice at all, but is what we want here
// Don't do this on your real site please!
while(performance.now() - start < milliseconds) {
// Log once a second
lastTime = performance.now() - lastCheck
if (lastTime >= 1000) {
console.log(`Still blocking ${Math.round(performance.now() - start, 0)} ms out of ${milliseconds} ms`);
lastCheck = performance.now();
}
}
}
// Load web-vitals.js and log LCP updates to console
var script = document.createElement('script');
script.src = 'https://unpkg.com/web-vitals@4/dist/web-vitals.attribution.iife.js';
script.onload = function () {
window.webVitals.onLCP(({value}) => {
console.log(`LCP time: ${Math.round(value)} ms`);
}, {reportAllChanges: true});
};
document.head.appendChild(script);
// Block page for 3 seconds to simulate a slow loading page
console.log('Simulate slow loading page by blocking page;');
blockPause(3000);
console.log('Page loaded');
এর মাধ্যমে, আপনার ডেমো সাইটটি সেট আপ করা উচিত। এটি সম্পর্কে ধারণা পেতে চারপাশে ক্লিক করুন। আপনার লক্ষ্য করা উচিত যে মূল থ্রেড কৃত্রিমভাবে ব্লক করার কারণে পৃষ্ঠা 2 এবং 3 লোড হতে ধীর গতিতে চলছে।
DevTools কনসোল খোলা থাকলে, আপনি script.js থেকে কনসোল লগগুলি দেখতে পাবেন:

আপনি ব্লকিং, ডিবাগ বার্তা দেখতে পাবেন, এবং আমাদের ডামি ব্লকিং ফাংশন দ্বারা মূল থ্রেডটি ব্লক করার কারণে এই পৃষ্ঠাটি তার LCP প্রদর্শন করতে 3,658 মিলিসেকেন্ড সময় নিয়েছে। ডামি ব্লকিং ফাংশনের কারণে এটি একটি ধীর পৃষ্ঠা, তবে এটি এমন একটি পৃষ্ঠাকে প্রতিনিধিত্ব করে যা যেকোনো কারণেই হোক না কেন। আসুন দেখি স্পেকুলেশন রুলস API ব্যবহার করে কীভাবে এটি দ্রুত করা যায়।
৪. URL তালিকার অনুমানের নিয়ম যোগ করুন
আপনি যে প্রথম অনুমানের নিয়মটি যোগ করবেন তা হল হার্ডকোডেড URL তালিকাটি প্রিরেন্ডার করা।
Glitch-এ নামের উপর ঘোরানোর সময় প্রদর্শিত তিন বিন্দু মেনুতে ক্লিক করে index.html ডকুমেন্টটি ডুপ্লিকেট করুন:

page1-url-speculations.html এর একটি নতুন নাম লিখুন।
স্পেকুলেশন রুলস হল একটি JSON ফর্ম্যাটেড <script> ট্যাগ যার type="speculationrules" আছে।
page1-url-speculations.html ফাইলটি সম্পাদনা করুন এবং পৃষ্ঠায় নিম্নলিখিত কোডটি যুক্ত করুন। এটি আসলে কোথায় তা বিবেচ্য নয়, তবে ক্লোজিং বডি ট্যাগ ( </body> ) এর ঠিক আগে পৃষ্ঠার বাকি অংশের বেশিরভাগ অংশ প্রথমে প্রক্রিয়া করার অনুমতি দেওয়া ভাল।
<script type="speculationrules">
{
"prerender": [
{
"urls": ["page2.html", "page3.html"]
}
]
}
</script>
আর এই তো! আপনার পৃষ্ঠায় তাৎক্ষণিক লোডিং যোগ করার জন্য এটুকুই প্রয়োজন!
এই নিয়মে বলা হয়েছে যে page2.html এবং page3.html url গুলিকে প্রিরেন্ডার করতে হবে যাতে উভয় পৃষ্ঠা ব্যাকগ্রাউন্ডে লোড হয়, ব্যবহারকারী যখন কোনও লিঙ্কে ক্লিক করেন তখন এর জন্য প্রস্তুত থাকে।
৫. জল্পনা-কল্পনার নিয়মগুলো বাস্তবে দেখা
আসুন আমরা এটিকে বাস্তবে দেখি। যদি আপনি page1-url-speculations.html পৃষ্ঠাটি লোড করেন, তাহলে মূল index.html পৃষ্ঠা থেকে কিছুই আলাদা বলে মনে হবে না। তবে, ব্যাকগ্রাউন্ডে, Chrome page2.html এবং page3.html প্রি-রেন্ডারিং শুরু করেছে। আপনি এগুলিকে লুকানো ব্যাকগ্রাউন্ড ট্যাব হিসাবে ভাবতে পারেন। একবার আপনি লিঙ্কটিতে ক্লিক করলে, Chrome বর্তমান পৃষ্ঠাটিকে সেই প্রি-রেন্ডার করা পৃষ্ঠার সাথে সোয়াপ করবে। লোড হওয়ার পরে কমপক্ষে 3 সেকেন্ড অপেক্ষা করলে এবং লিঙ্কগুলিতে ক্লিক করলে, আপনি লক্ষ্য করবেন যে সেগুলি তাৎক্ষণিকভাবে লোড হচ্ছে এবং LCP প্রায় শূন্য!

এখানে আপনি ৫০ মিলিসেকেন্ডের LCP দেখতে পাবেন— প্রস্তাবিত "ভালো" ২.৫ সেকেন্ডের থ্রেশহোল্ডের চেয়ে অনেক দ্রুত এবং বেশিরভাগ লোকের ক্ষেত্রে এটি "তাৎক্ষণিক" হিসাবে বিবেচিত হবে।
index.html এর মূল হোম পেজের সাথে এটি তুলনা করুন যেখানে পৃষ্ঠাগুলির মধ্যে নেভিগেট করা ধীর এবং প্রতিক্রিয়াহীন বলে মনে হয়।
এটি কেবল একটি সাধারণ ডেমো সাইট, এবং ধীর লোডিং কৃত্রিম। আশা করি, আপনি ইতিমধ্যেই API এর শক্তি দেখতে এবং বুঝতে পারবেন। আপনাকে মূল পৃষ্ঠার কোড পরিবর্তন করার প্রয়োজন ছিল না, আপনাকে কেবল পৃষ্ঠায় অনুমানের নিয়মগুলি যুক্ত করতে হয়েছিল।
যদি আপনি পুরো ৩ সেকেন্ড লোডিং সময় শেষ হওয়ার আগে ক্লিক করেন, তাহলে আংশিকভাবে লোড হওয়া পৃষ্ঠাটি বর্তমান পৃষ্ঠাটি প্রতিস্থাপন করবে এবং আপনি কনসোলে অবশিষ্ট ব্লকিং বার্তাগুলি দেখতে পাবেন:

ক্রোম ব্যবহারকারীর সামনে লোডিং সম্পন্ন করে এবং এখানে আপনি ১ সেকেন্ডের LCP দেখতে পাবেন—সম্পূর্ণ প্রি-রেন্ডার করা অবস্থায় ৫০ মিলিসেকেন্ডের কাছাকাছি তাৎক্ষণিক অনুভূতি নয়, তবে প্রি-রেন্ডার করা হয়নি এমন পৃষ্ঠা লোডের জন্য ৩ সেকেন্ডের চেয়েও ভালো। হেড স্টার্টটি এখনও পৃষ্ঠা লোডকে লক্ষণীয়ভাবে উন্নত করেছে।
৬. জাভাস্ক্রিপ্ট দিয়ে ডিবাগিং
পৃষ্ঠাটি সক্রিয় হওয়ার পরে ইভেন্ট হ্যান্ডলারটি চালু করার জন্য আপনি জাভাস্ক্রিপ্ট ব্যবহার করতে পারেন।
// এর ঠিক আগে script.js ফাইলে নিম্নলিখিত কোডটি যোগ করুন। // Block page for 3 seconds to simulate a slow loading page :
// Load when the page is activated
document.addEventListener('prerenderingchange', () => {
console.log(`The page has been activated!`);
const activationStart = Math.round(performance.getEntriesByType('navigation')[0].activationStart);
console.log(`The page was activated at: ${activationStart}`);
});
যদি আপনি page1-url-speculations.html পৃষ্ঠায় ফিরে যান, পৃষ্ঠাটি প্রি-রেন্ডার হওয়ার জন্য কয়েক সেকেন্ড অপেক্ষা করুন, এবং তারপরে যেকোনো একটি লিঙ্কে ক্লিক করুন, তাহলে আপনি নিম্নলিখিত স্ক্রিনশটের মতো কিছু দেখতে পাবেন:

এখানে আপনি দেখতে পাচ্ছেন যে পৃষ্ঠাটি লোড শুরু হওয়ার পর ৪,২৯৮ মিলিসেকেন্ডে পৃষ্ঠাটি সক্রিয় হয়েছিল। পৃষ্ঠা লোডের সময় ৪ সেকেন্ডের মাথায় ভালো শুরু হয়েছিল!
লগের ক্রম দেখেই বোঝা যাবে যে LCP ট্রিগার হওয়ার আগে অ্যাক্টিভেশন ইভেন্টটি প্রথমে শুরু হয়। যদিও ততক্ষণে পৃষ্ঠাটি সম্পূর্ণরূপে লোড হয়ে যেত, LCP-এর জন্য একটি "পেইন্ট" প্রয়োজন - এটি নামেই আছে! তাই যদিও পৃষ্ঠাটি ব্যাকগ্রাউন্ডে প্রি-রেন্ডার করা থাকে, পৃষ্ঠাটি সক্রিয় না হওয়া পর্যন্ত কোনও প্রকৃত "পেইন্ট" ঘটে না। অতএব অ্যাক্টিভেশন এবং LCP সময়ের মধ্যে একটি ছোট বিলম্ব হবে। এই ক্ষেত্রে 128 মিলিসেকেন্ড। যা ব্যবহারকারীর জন্য প্রায় তাৎক্ষণিক!
আপনি আরও দেখতে পাচ্ছেন যে এই উদাহরণে অ্যাক্টিভেশন সময় 4,298 মিলিসেকেন্ড, তবে LCP সময় 128 মিলিসেকেন্ডের চেয়ে অনেক কম। পারফরম্যান্স মেট্রিক্সের জন্য সমস্ত সময় পরিমাপ পৃষ্ঠাটি লোড হওয়া শুরু হওয়ার উপর ভিত্তি করে, তবে LCP রেকর্ড করার জন্য ব্যবহৃত ওয়েব-ভাইটালস লাইব্রেরিতে ব্যবহারকারীর ক্ষেত্রে LCP পরিমাপ করার জন্য activationStart সময় বিয়োগ করার জন্য বিশেষ যুক্তি রয়েছে। Chrome ব্যবহারকারী অভিজ্ঞতা প্রতিবেদন (CrUX) এর জন্য LCP গণনা করা হয় , যা Google Search Console-এ PageSpeed Insights এবং Core Web Vitals রিপোর্টের মতো সরঞ্জামগুলিকে শক্তি দেয়।
৭. DevTools দিয়ে ডিবাগিং
কনসোল লগিং অবশ্যই ডিবাগিংয়ের একটি উপায় (কে ডিবাগ করার জন্য একটি ভাল পুরানো console.log পছন্দ করে না!), তবে স্পেকুলেশন রুলস ডিবাগ করার জন্য Chrome-এর DevTools-এ চমৎকার সমর্থন রয়েছে।
page1-url-speculations.html পৃষ্ঠায় ফিরে যান, এবং অ্যাপ্লিকেশন প্যানেলটি খুলুন এবং ব্যাকগ্রাউন্ড সার্ভিসেস বিভাগের অধীনে স্পেকুলেটিভ লোডস ট্যাবে নেভিগেট করুন:

এই স্ক্রিনটি দেখায় যে পৃষ্ঠাটি নিজেই অনুমান করা হয়নি (ডানদিকের উপরের অংশ), বরং এটি দুটি অনুমানের সূচনা করেছিল । "সকল অনুমানের নিয়ম দেখুন" লিঙ্কে ক্লিক করুন, যা আপনাকে নিয়মের তালিকা সহ একটি স্ক্রিন দেখাবে (এই পৃষ্ঠায় কেবল একটি আছে)। তবে আরও আকর্ষণীয় হল "সকল অনুমানের দেখুন " লিঙ্কটি, যা আপনাকে অনুমানের ট্যাবে নিয়ে যায়:

এখানে আপনি দেখতে পাচ্ছেন যে দুটি পৃষ্ঠা অনুমান করা হয়েছে, এবং দুটিই প্রস্তুত , যার অর্থ হল সেগুলি প্রিরেন্ডার করা এবং সক্রিয় করার জন্য প্রস্তুত। এর অর্থ এই নয় যে পৃষ্ঠাটি সম্পূর্ণরূপে লোডিং শেষ হয়েছে - যেমন আপনি আগে দেখেছেন - বরং প্রিরেন্ডার সফলভাবে শুরু হয়েছে এবং পৃষ্ঠাটি সক্রিয় করার জন্য প্রস্তুত।
যদি কোনও পৃষ্ঠা প্রি-রেন্ডার করতে ব্যর্থ হয়, তাহলে অনুমান কেন ব্যর্থ হয়েছে সে সম্পর্কে আরও বিশদ জানতে আপনি সেই লাইনে ক্লিক করতে পারেন। উদাহরণস্বরূপ, অল্প সংখ্যক জাভাস্ক্রিপ্ট API প্রি-রেন্ডারিংয়ের সাথে সামঞ্জস্যপূর্ণ নয়, যা প্রি-রেন্ডার প্রচেষ্টা বাতিল করবে।
৮. ডকুমেন্ট নিয়মের সাথে স্বয়ংক্রিয় লিঙ্ক জল্পনা
এই অনুমানগুলিতে, URL গুলির একটি হার্ড-কোডেড তালিকা ব্যবহার করা হয়েছিল। এটি এমন কিছু পরিস্থিতিতে কার্যকর যেখানে অনুমান করার জন্য URL(গুলি) আগে থেকে জানা থাকে। অথবা আরও উন্নত ক্ষেত্রে যেখানে URL গুলি গণনা করা যেতে পারে এবং জাভাস্ক্রিপ্টের মাধ্যমে গতিশীলভাবে পৃষ্ঠায় সন্নিবেশ করা যেতে পারে।
তবে, এটা খুবই সাধারণ যে, পৃষ্ঠার কোন লিঙ্কে (যদি থাকে!) ভিজিটর ক্লিক করবেন তা অজানা বা ভবিষ্যদ্বাণী করা কঠিন। প্রতিটি পৃষ্ঠায় সমস্ত লিঙ্ক আগে থেকে প্রি-রেন্ডার করা একদিকে ক্লান্তিকর, অন্যদিকে খুব অপচয়কর। তাই আপনি যা চান তা হল পৃষ্ঠার নির্দিষ্ট লিঙ্কগুলি বিবেচনা করা, তবে আরও স্পষ্ট ইঙ্গিত সহ যে ব্যবহারকারী কোনও লিঙ্কে ক্লিক করতে চলেছেন। ডকুমেন্টের নিয়মগুলি এটির অনুমতি দেয়।
index.html ফাইলটি আবার page1-document-speculations.html ফাইলে ডুপ্লিকেট করুন, এবং এবার, নিম্নলিখিত নিয়মটি যোগ করুন—যদি ভালো জায়গা হয়, তাহলে </body> ক্লোজিং ট্যাগের ঠিক আগে।
<script type="speculationrules">
{
"prerender": [{
"where": {
"and": [
{ "href_matches": "/*" },
{ "not": {"selector_matches": ".do-not-prerender"}}
]
},
"eagerness": "moderate"
}]
}
</script>
এর অর্থ হল, সমস্ত একই-অরিজিন লিঙ্ক ( /* দিয়ে শুরু) প্রিরেন্ডার করা—যদি <a> এলিমেন্টে do-not-prerender এর একটি ক্লাস থাকে তবে তা ছাড়া। এই উদাহরণে, পৃষ্ঠাগুলি moderate আগ্রহের সাথে প্রিরেন্ডার করা হয় (যা আমরা পরবর্তী পৃষ্ঠায় আলোচনা করব)।
যখন আপনি পৃষ্ঠাটিতে নেভিগেট করবেন তখন আপনি দুটি সম্ভাব্য অনুমান দেখতে পাবেন এবং উভয়ই Not Triggered :

কোনও একটি লিঙ্কের উপর ঘোরাফেরা করলেই জল্পনা শুরু হয়:

লিঙ্কটিতে ক্লিক করার পর, পূর্বনির্ধারিত পৃষ্ঠাটি লোড হবে। পৃষ্ঠাটি লোড করার জন্য পর্যাপ্ত সময় দেওয়া হলে এটি তাৎক্ষণিক মনে হতে পারে, অথবা লিঙ্কটি ক্লিক করার সময় পৃষ্ঠা লোড সম্পূর্ণ না হলে কিছুটা দ্রুত মনে হতে পারে। যাই হোক না কেন, অনুমানের নিয়ম ব্যবহার না করার চেয়ে এটি LCP সময়কে আরও ভাল করে তুলবে।
ডকুমেন্ট নিয়মগুলি আপনার ওয়েবসাইটে দ্রুত অনুমানমূলক নেভিগেশন যোগ করার একটি শক্তিশালী উপায়, কোন URL গুলি প্রি-রেন্ডার করতে হবে তা সাবধানে বিবেচনা না করেই। এগুলি প্রি-রেন্ডার সম্পূর্ণ করার জন্য কম সময় দেয়, কিন্তু তবুও পরবর্তী নেভিগেশনের জন্য একটি প্রাথমিক সূচনা প্রদান করে এবং এইভাবে ভবিষ্যতের পৃষ্ঠা লোড উন্নত করতে সহায়তা করে।
৯. কখন অনুমান করতে হবে তা নির্দেশ করার জন্য ব্যবহারকারীর আগ্রহ
পূর্ববর্তী ধাপে "eagerness": "moderate" ব্যবহার করা হয়েছিল। ৪টি আগ্রহ সেটিংস রয়েছে:
-
immediate: এটি যত তাড়াতাড়ি সম্ভব অনুমান করার জন্য ব্যবহৃত হয় - অর্থাৎ, অনুমানের নিয়মগুলি পালন করার সাথে সাথে। -
eager: এটিimmediateসেটিংয়ের সাথে একই রকম আচরণ করে, কিন্তু ভবিষ্যতে, আমরা এটিকেimmediateএবংmoderateমাঝামাঝি কোথাও রাখার চেষ্টা করছি। -
moderate: যদি আপনি 200 মিলিসেকেন্ডের জন্য একটি লিঙ্কের উপর হোভার করেন (অথবাpointerdownইভেন্টে যদি এটি আগে হয়, এবং মোবাইলে যেখানে কোনও হোভার ইভেন্ট নেই) তাহলে এটি অনুমান সম্পাদন করে। -
conservative: এটি পয়েন্টার বা টাচ ডাউনের উপর অনুমান করে।
eagerness সেটিংটি URL-ভিত্তিক তালিকার নিয়ম বা where -ভিত্তিক নথির নিয়ম উভয়ের জন্যই ব্যবহার করা যেতে পারে। immediate এবং eager সেটিংস সাধারণত তালিকার নিয়মের জন্য বেশি কার্যকর কারণ আপনি URL গুলি জানেন এবং তাই সর্বাধিক সময় পাওয়ার জন্য যত তাড়াতাড়ি সম্ভব সেগুলি অনুমান করা উচিত। moderate এবং conservative সাধারণত ডকুমেন্টের নিয়মের জন্য বেশি কার্যকর যেখানে অনুমান করার জন্য সঠিক URL সাধারণত জানা থাকে না।
কখন জল্পনা-কল্পনা ঘটে তা দেখার জন্য DevTools ব্যবহার করে আপনার পৃষ্ঠাগুলিতে বিভিন্ন আগ্রহের সেটিংস পরীক্ষা করুন।
১০. উপসংহার
অভিনন্দন, আপনি এই কোডল্যাবের শেষে পৌঁছে গেছেন এবং এখন বুঝতে হবে যে স্পেকুলেশন রুলস এপিআই একটি শক্তিশালী এপিআই যা কয়েকটি লাইন কোড ব্যবহার করে সাইটগুলিতে যোগ করা যেতে পারে।
এই সংক্ষিপ্ত ভূমিকায় আপনি এই API-এর সম্ভাবনার উপরিভাগটি কেবল তুলে ধরেছেন, তবে আপনার ওয়েবসাইটে সমর্থন যোগ করার জন্য এটি যথেষ্ট।
আরও উন্নত বিষয়ের জন্য, যার মধ্যে বিশ্লেষণ বা বিজ্ঞাপনের জন্য আপনার বিবেচনার প্রয়োজন হতে পারে এমন বিবেচ্য বিষয়গুলিও অন্তর্ভুক্ত, নীচের আরও জানুন লিঙ্কগুলি দেখুন।
আরও জানুন
- তাৎক্ষণিক পৃষ্ঠা নেভিগেশনের জন্য Chrome-এ পৃষ্ঠাগুলি প্রিরেন্ডার করুন
- অনুমান সংক্রান্ত নিয়মগুলি ডিবাগ করা
প্রতিক্রিয়া
এই কোডল্যাব সম্পর্কে আপনার মতামত জানতে এবং আপনার যদি কোনও প্রশ্ন বা উদ্বেগ থাকে, তাহলে আমরা তা জানতে আগ্রহী।