First Contentful Paint (FCP)

دعم المتصفح

  • Chrome: 60
  • الحافة: 79.
  • Firefox: 84.
  • Safari: الإصدار 14.1.

المصدر

ما هي سرعة عرض المحتوى على الصفحة (FCP)؟

يقيس مقياس "سرعة عرض أوّل محتوى مرئي" (FCP) الوقت المنقضي منذ أن انتقل المستخدِم إلى الصفحة لأول مرّة إلى أن يتم عرض أي جزء من محتوى الصفحة على الشاشة. بالنسبة إلى هذا المقياس، يشير "المحتوى" إلى النصوص أو الصور (بما في ذلك صور الخلفية) أو عناصر <svg> أو عناصر <canvas> غير البيضاء.

المخطط الزمني لسرعة عرض المحتوى على الصفحة من google.com
في مخطط تحميل الصفحة هذا، تحدث سرعة عرض المحتوى على الصفحة في الإطار الثاني، لأنّه هو الوقت الذي يتم فيه عرض أول عنصرَي نص وصورة على الشاشة.

في المخطط الزمني للتحميل الموضح في الصورة السابقة، تحدث تقنية FCP في الإطار الثاني، كما يحدث عند عرض أول عناصر النص والصورة على الشاشة.

ستلاحظ أنه على الرغم من عرض بعض المحتوى، لم يتم عرض كله. من المهمّ التمييز بين مقياس سرعة عرض المحتوى على الصفحة ومقياس سرعة عرض أكبر محتوى مرئي (LCP) الذي يهدف إلى قياس الوقت الذي اكتمل فيه تحميل المحتوى الرئيسي للصفحة.

ما هي نتيجة FCP الجيدة؟

لتقديم تجربة جيدة للمستخدم، يجب أن تسعى المواقع الإلكترونية إلى أن تكون قيمة First Contentful Paint 1.8 ثانية أو أقل. لضمان تحقيق هذا المستهدف لمعظم المستخدمين، يمكنك قياس الشريحة المئوية الخامسة والسبعين من عمليات تحميل الصفحات، مقسّمة على الأجهزة الجوّالة وأجهزة الكمبيوتر المكتبي.

تبلغ قيم FCP الجيدة 1.8 ثانية أو أقل، والقيم الضعيفة تزيد عن 3.0 ثانية.
تبلغ قيم FCP الجيدة 1.8 ثانية أو أقل. القيم غير المقبولة أكبر من 3.0 ثوانٍ

كيفية قياس عدد مرّات الظهور النهائية

يمكن قياس معدّل التحويل الناجح في المختبر أو في الميدان، وهو متاح في الأدوات التالية:

الأدوات الميدانية

أدوات التمرين المعملي

قياس وقت عرض الصفحة في JavaScript

لقياس وقت عرض الصفحة في JavaScript، يمكنك استخدام Paint Timing API. يوضح المثال التالي كيفية إنشاء PerformanceObserver يرصد إدخال paint باسم first-contentful-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 الذي تم تسجيله على وقت عرض أول عنصر غني بالمحتوى. ومع ذلك، في بعض الحالات، يكون هذا الإدخال غير صالح لقياس "سرعة عرض المحتوى على الصفحة".

يسرد القسم التالي الاختلافات بين ما تُبلغ عنه واجهة برمجة التطبيقات وكيفية احتساب المقياس.

الاختلافات بين المقياس وواجهة برمجة التطبيقات

  • سترسِل واجهة برمجة التطبيقات الإدخال first-contentful-paint للصفحات التي تم تحميلها في علامة تبويب في الخلفية، ولكن يجب تجاهل هذه الصفحات عند احتساب سرعة عرض المحتوى على الصفحة (يجب مراعاة توقيتات عرض الصفحة الأولى فقط إذا كانت الصفحة معروضة في المقدّمة طوال الوقت).
  • لا تسجِّل واجهة برمجة التطبيقات إدخالات first-contentful-paint عند استعادة الصفحة من ذاكرة التخزين المؤقت للرجوع/الانتقال إلى الأمام، ولكن يجب قياس وقت التحميل الأولي في هذه الحالات لأنّ المستخدمين يواجهونها كزيارات صفحة مختلفة.
  • قد لا تبلّغ واجهة برمجة التطبيقات عن أوقات عرض اللقطات من إطارات iframe من مصادر متعددة، ولكن لقياس "سرعة عرض المحتوى على الصفحة" بشكل صحيح، يجب مراعاة جميع اللقطات. يمكن للإطارات الفرعية استخدام واجهة برمجة التطبيقات للإبلاغ عن أوقات الرسم إلى الإطار الرئيسي للتجميع.
  • تقيس واجهة برمجة التطبيقات مقياس FCP من بداية التنقّل، ولكن بالنسبة إلى الصفحات التي تمّ عرضها مسبقًا، يجب قياس مقياس FCP من activationStart لأنّ ذلك يتوافق مع وقت FCP الذي يشهده المستخدم.

بدلاً من تذكُّر كل هذه الاختلافات الدقيقة، يمكن للمطوّرين استخدام مكتبة JavaScript web-vitals لقياس سرعة عرض المحتوى على الصفحة (FCP) التي تعالج هذه الاختلافات نيابةً عنك (حيثما أمكن، مع العِلم بأنّه لم يتم تناول مشكلة إطار iframe):

import {onFCP} from 'web-vitals';

// Measure and log FCP as soon as it's available.
onFCP(console.log);

يمكنك الرجوع إلى رمز المصدر onFCP() للاطّلاع على مثال كامل عن كيفية قياس "سرعة عرض المحتوى على الصفحة" (FCP) في JavaScript.

كيفية تحسين مقياس FCP

للتعرّف على كيفية تحسين "سرعة عرض المحتوى على الصفحة" (FCP) لموقع إلكتروني معيَّن، يمكنك إجراء تدقيق لأداء Lighthouse والتركيز على أي فرص أو بيانات تشخيص محددة يقترحها التدقيق.

للتعرّف على كيفية تحسين سرعة عرض المحتوى على الصفحة بشكل عام (لأي موقع إلكتروني)، يمكنك الاطّلاع على أدلة الأداء التالية:

سجلّ التغييرات

في بعض الأحيان، يتم اكتشاف أخطاء في واجهات برمجة التطبيقات المستخدَمة لقياس المقاييس، وفي بعض الأحيان في تعريفات المقاييس نفسها. ونتيجةً لذلك، يجب إجراء تغييرات في بعض الأحيان، ويمكن أن تظهر هذه التغييرات كتحسينات أو تراجعات في التقارير ولوحات البيانات الداخلية.

لمساعدتك في إدارة ذلك، سيتم عرض جميع التغييرات التي تطرأ على تنفيذ هذه المقاييس أو تعريفها في سجلّ التغييرات هذا.

إذا كانت لديك ملاحظات بشأن هذه المقاييس، يمكنك تقديمها في مجموعة Google الخاصة بملاحظات مؤشرات أداء الويب.