FCP কি?
ফার্স্ট কনটেন্টফুল পেইন্ট (FCP) সময় পরিমাপ করে যখন ব্যবহারকারী প্রথম পৃষ্ঠায় নেভিগেট করেন থেকে কখন পৃষ্ঠার বিষয়বস্তুর কোনো অংশ স্ক্রিনে রেন্ডার করা হয়। এই মেট্রিকের জন্য, "সামগ্রী" বলতে পাঠ্য, ছবি (পটভূমির ছবি সহ), <svg>
উপাদান বা সাদা নয় এমন <canvas>
উপাদান বোঝায়।
পূর্ববর্তী চিত্রে চিত্রিত লোডিং টাইমলাইনে, FCP দ্বিতীয় ফ্রেমে ঘটে, যেমনটি যখন প্রথম পাঠ্য এবং চিত্র উপাদানগুলি স্ক্রিনে রেন্ডার করা হয়।
আপনি লক্ষ্য করবেন যে যদিও কিছু বিষয়বস্তু রেন্ডার করা হয়েছে, তবে এর সবগুলোই রেন্ডার হয়নি। ফার্স্ট কনটেন্টফুল পেইন্ট এবং লার্জেস্ট কনটেন্টফুল পেইন্ট (এলসিপি)-এর মধ্যে এটি একটি গুরুত্বপূর্ণ পার্থক্য - যার লক্ষ্য পৃষ্ঠার প্রধান বিষয়বস্তু লোড হওয়া শেষ হলে পরিমাপ করা।
একটি ভাল FCP স্কোর কি?
একটি ভাল ব্যবহারকারীর অভিজ্ঞতা প্রদানের জন্য, সাইটগুলিকে 1.8 সেকেন্ড বা তার কম সময়ের একটি প্রথম বিষয়বস্তুযুক্ত পেইন্ট রাখার চেষ্টা করা উচিত৷ আপনি আপনার বেশিরভাগ ব্যবহারকারীর জন্য এই লক্ষ্যে পৌঁছেছেন তা নিশ্চিত করার জন্য, পরিমাপ করার জন্য একটি ভাল থ্রেশহোল্ড হল পৃষ্ঠা লোডের 75 তম শতাংশ , যা মোবাইল এবং ডেস্কটপ ডিভাইস জুড়ে বিভক্ত।
কিভাবে FCP পরিমাপ করা যায়
FCP ল্যাবে বা ক্ষেত্রে পরিমাপ করা যেতে পারে এবং এটি নিম্নলিখিত সরঞ্জামগুলিতে উপলব্ধ:
ক্ষেত্র সরঞ্জাম
- পেজস্পিড ইনসাইট
- ক্রোম ব্যবহারকারীর অভিজ্ঞতা প্রতিবেদন
- সার্চ কনসোল (স্পিড রিপোর্ট)
-
web-vitals
জাভাস্ক্রিপ্ট লাইব্রেরি
ল্যাব সরঞ্জাম
জাভাস্ক্রিপ্টে FCP পরিমাপ করুন
জাভাস্ক্রিপ্টে FCP পরিমাপ করতে, আপনি পেইন্ট টাইমিং API ব্যবহার করতে পারেন। নিম্নলিখিত উদাহরণটি দেখায় কিভাবে একটি PerformanceObserver
তৈরি করতে হয় যেটি first-contentful-paint
নামের একটি paint
এন্ট্রি শোনে এবং কনসোলে লগ করে।
new PerformanceObserver((entryList) => {
for (const entry of entryList.getEntriesByName('first-contentful-paint')) {
console.log('FCP candidate:', entry.startTime, entry);
}
}).observe({type: 'paint', buffered: true});
পূর্ববর্তী কোড স্নিপেটে, লগ করা first-contentful-paint
এন্ট্রি আপনাকে বলবে যে প্রথম বিষয়বস্তুপূর্ণ উপাদানটি কখন আঁকা হয়েছিল। যাইহোক, কিছু ক্ষেত্রে এই এন্ট্রি FCP পরিমাপের জন্য বৈধ নয়।
নিম্নলিখিত বিভাগে এপিআই রিপোর্ট এবং কিভাবে মেট্রিক গণনা করা হয় তার মধ্যে পার্থক্যগুলি তালিকাভুক্ত করে৷
মেট্রিক এবং API-এর মধ্যে পার্থক্য
- API একটি ব্যাকগ্রাউন্ড ট্যাবে লোড করা পৃষ্ঠাগুলির জন্য একটি
first-contentful-paint
এন্ট্রি পাঠাবে, কিন্তু FCP গণনা করার সময় সেই পৃষ্ঠাগুলিকে উপেক্ষা করা উচিত (প্রথম পেইন্টের সময়গুলি শুধুমাত্র তখনই বিবেচনা করা উচিত যদি পৃষ্ঠাটি পুরো সময় অগ্রভাগে থাকে)। - যখন পৃষ্ঠাটি পিছনে/ফরোয়ার্ড ক্যাশে থেকে পুনরুদ্ধার করা হয় তখন API
first-contentful-paint
এন্ট্রি রিপোর্ট করে না, তবে FCP এই ক্ষেত্রে পরিমাপ করা উচিত যেহেতু ব্যবহারকারীরা তাদের আলাদা পৃষ্ঠা ভিজিট হিসাবে অনুভব করে। - API ক্রস-অরিজিন iframes থেকে পেইন্টের সময় রিপোর্ট নাও করতে পারে , কিন্তু FCP সঠিকভাবে পরিমাপ করতে আপনার সমস্ত ফ্রেম বিবেচনা করা উচিত। সাব-ফ্রেমগুলি তাদের পেইন্টের সময়গুলিকে একত্রিত করার জন্য মূল ফ্রেমে রিপোর্ট করতে API ব্যবহার করতে পারে।
- API ন্যাভিগেশন শুরু থেকে FCP পরিমাপ করে, কিন্তু পূর্ব-প্রস্তুত করা পৃষ্ঠাগুলির জন্য FCP
activationStart
থেকে পরিমাপ করা উচিত কারণ এটি ব্যবহারকারীর অভিজ্ঞতা অনুযায়ী FCP সময়ের সাথে মিলে যায়।
এই সমস্ত সূক্ষ্ম পার্থক্যগুলি মুখস্থ করার পরিবর্তে, বিকাশকারীরা FCP পরিমাপ করতে web-vitals
জাভাস্ক্রিপ্ট লাইব্রেরি ব্যবহার করতে পারে, যা আপনার জন্য এই পার্থক্যগুলি পরিচালনা করে (যেখানে সম্ভব — মনে রাখবেন iframe সমস্যাটি কভার করা হয়নি):
import {onFCP} from 'web-vitals';
// Measure and log FCP as soon as it's available.
onFCP(console.log);
কিভাবে জাভাস্ক্রিপ্টে FCP পরিমাপ করা যায় তার সম্পূর্ণ উদাহরণের জন্য আপনি onFCP()
এর সোর্স কোডটি দেখতে পারেন।
কিভাবে FCP উন্নত করা যায়
একটি নির্দিষ্ট সাইটের জন্য FCP কীভাবে উন্নত করা যায় তা শিখতে, আপনি একটি লাইটহাউস পারফরম্যান্স অডিট চালাতে পারেন এবং অডিটের পরামর্শে যে কোনও নির্দিষ্ট সুযোগ বা ডায়াগনস্টিকসের দিকে মনোযোগ দিতে পারেন।
সাধারণভাবে (যেকোনো সাইটের জন্য) কীভাবে FCP উন্নত করা যায় তা শিখতে, নিম্নলিখিত কর্মক্ষমতা নির্দেশিকা পড়ুন:
- রেন্ডার-ব্লকিং রিসোর্স বাদ দিন
- CSS ছোট করুন
- অব্যবহৃত CSS সরান
- অব্যবহৃত জাভাস্ক্রিপ্ট সরান
- প্রয়োজনীয় উত্সের সাথে পূর্ব সংযোগ করুন৷
- সার্ভার প্রতিক্রিয়া সময় হ্রাস করুন (TTFB)
- একাধিক পৃষ্ঠা পুনঃনির্দেশ এড়িয়ে চলুন
- প্রিলোড কী অনুরোধ
- বিশাল নেটওয়ার্ক পেলোড এড়িয়ে চলুন
- একটি দক্ষ ক্যাশে নীতির সাথে স্ট্যাটিক সম্পদ পরিবেশন করুন
- একটি অতিরিক্ত DOM আকার এড়িয়ে চলুন
- সমালোচনামূলক অনুরোধের গভীরতা কমিয়ে দিন
- ওয়েবফন্ট লোডের সময় পাঠ্য দৃশ্যমান থাকে তা নিশ্চিত করুন
- অনুরোধের সংখ্যা কম রাখুন এবং স্থানান্তরের আকার ছোট রাখুন
চেঞ্জলগ
মাঝে মাঝে, মেট্রিক্স পরিমাপ করতে ব্যবহৃত API-এ বাগগুলি আবিষ্কৃত হয়, এবং কখনও কখনও মেট্রিক্সের সংজ্ঞায়। ফলস্বরূপ, পরিবর্তনগুলি কখনও কখনও করা আবশ্যক, এবং এই পরিবর্তনগুলি আপনার অভ্যন্তরীণ রিপোর্ট এবং ড্যাশবোর্ডে উন্নতি বা রিগ্রেশন হিসাবে দেখাতে পারে৷
এটি পরিচালনা করতে আপনাকে সাহায্য করার জন্য, এই মেট্রিক্সের বাস্তবায়ন বা সংজ্ঞার সমস্ত পরিবর্তন এই চেঞ্জলগে প্রদর্শিত হবে।
আপনার যদি এই মেট্রিক্সের জন্য প্রতিক্রিয়া থাকে, আপনি ওয়েব-ভিটালস-ফিডব্যাক Google গ্রুপে তা প্রদান করতে পারেন।