عندما تفتح صفحة ويب، يطلب المتصفّح مستند HTML من الخادم ويحلّل محتواه ويُرسل طلبات منفصلة لأي موارد مرجعية. بصفتك مطورًا، تعرف بالفعل جميع الموارد التي تحتاجها صفحتك وأي منها أكثر أهمية. ويمكنك الاستفادة من هذه المعلومات لطلب الموارد المهمة مسبقًا وتسريع عملية التحميل. وتوضّح هذه المشاركة كيفية تحقيق ذلك باستخدام <link rel="preload">
.
طريقة عمل التحميل المُسبق
يناسب التحميل المُسبق الموارد التي يكتشفها المتصفّح عادةً في وقت متأخر.
من خلال التحميل المسبق لمورد معين، فأنت تخبر المتصفح أنك تريد جلبه في وقت أقرب من اكتشافه للمتصفح بخلاف ذلك لأنك متأكد من أهميته للصفحة الحالية.
تمثل سلسلة الطلبات المهمة ترتيب الموارد التي يتم منحها الأولوية واسترجاعها بواسطة المتصفّح. تحدِّد أداة Lighthouse مواد العرض الموجودة في المستوى الثالث من هذه السلسلة على أنّها مواد العرض التي تم اكتشافها مؤخرًا. يمكنك استخدام عملية تدقيق التحميل المُسبق للطلبات الرئيسية لتحديد الموارد التي يجب تحميلها مُسبقًا.
يمكنك تحميل الموارد مسبقًا من خلال إضافة علامة <link>
باستخدام rel="preload"
إلى رأس مستند HTML:
<link rel="preload" as="script" href="critical.js">
يخزِّن المتصفّح الموارد التي تم تحميلها مسبقًا في ذاكرة التخزين المؤقت لتكون متاحة على الفور عند الحاجة. (لا ينفّذ النصوص البرمجية أو يطبق أوراق الأنماط).
يتم تنفيذ تعديلات الموارد، على سبيل المثال، preconnect
وprefetch
بالشكل الذي يناسبه المتصفِّح. ومن ناحية أخرى، فإنّ preload
إلزامي للمتصفّح. إنّ المتصفّحات الحديثة بارعة للغاية في تحديد أولويات الموارد، لذلك من المهم استخدام preload
باعتدال وتحميل الموارد الأكثر أهمية فقط مسبقًا.
تؤدي عمليات التحميل المُسبق غير المستخدَمة إلى ظهور تحذير Console في Chrome، بعد 3 ثوانٍ تقريبًا من حدث load
.
حالات الاستخدام
التحميل المُسبق للموارد المحدّدة في CSS
لا يتم اكتشاف الخطوط المحدَّدة باستخدام قواعد @font-face
أو صور الخلفية المحدّدة في ملفات CSS إلى أن ينزِّل المتصفِّح ملفات CSS هذه ويحلّلها. يضمن التحميل المُسبق لهذه الموارد جلبها قبل تنزيل ملفات CSS.
التحميل المُسبق لملفات CSS
إذا كنت تستخدم أسلوب CSS الأساسي، يمكنك تقسيم خدمة CSS إلى قسمَين. يتم تضمين خدمة CSS المهمة المطلوبة لعرض محتوى الجزء المرئي من الصفحة في <head>
من المستند، وعادة ما يتم التحميل الكسول في لغة CSS غير الأساسية باستخدام JavaScript. قد يؤدي انتظار تنفيذ JavaScript قبل تحميل لغة CSS غير المهمة إلى حدوث تأخير في العرض عند انتقال المستخدمين إلى أسفل الصفحة، لذا ننصح باستخدام <link rel="preload">
لبدء عملية التنزيل في وقت أقرب.
التحميل المُسبق لملفات JavaScript
نظرًا لأنّ المتصفحات لا تنفّذ ملفات محمّلة مسبقًا، يكون التحميل المُسبق مفيدًا للاسترجاع بشكل منفصل عن التنفيذ، ما قد يحسّن مقاييس مثل "وقت التفاعل". تعمل ميزة التحميل المُسبق بشكل أفضل في حال تقسيم حِزم JavaScript وتحميل الأجزاء المهمة مسبقًا فقط.
كيفية تنفيذ rel=preload
إنّ أبسط طريقة لتنفيذ preload
هي إضافة علامة <link>
إلى <head>
في المستند:
<head>
<link rel="preload" as="script" href="critical.js">
</head>
عند توفير السمة as
، يساعد المتصفّح في تحديد أولوية المورد الذي تم جلبه مسبقًا وفقًا لنوعه وضبط العناوين الصحيحة وتحديد ما إذا كان المورد متوفّرًا حاليًا في ذاكرة التخزين المؤقت. تشمل القيم المقبولة لهذه السمة ما يلي: script
وstyle
وfont
وimage
وسمات أخرى.
يتم تحميل بعض أنواع الموارد، مثل الخطوط، في وضع إخفاء الهوية. في هذه الحالة، عليك ضبط السمة crossorigin
باستخدام preload
:
<link rel="preload" href="ComicSans.woff2" as="font" type="font/woff2" crossorigin>
تقبل عناصر <link>
أيضًا السمة type
التي تحتوي على نوع MIME للمورد المرتبط. تستخدم المتصفّحات قيمة السمة type
للتأكد من تحميل الموارد مسبقًا فقط في حال كان نوع الملف متوافقًا. إذا كان المتصفّح لا يتيح استخدام نوع المورد المحدّد، سيتجاهل <link rel="preload">
.
يمكنك أيضًا تحميل أي نوع من الموارد مسبقًا من خلال عنوان HTTP يتضمّن العلامة Link
:
Link: </css/style.css>; rel="preload"; as="style"
من فوائد تحديد preload
في عنوان HTTP أنّ المتصفّح لا يحتاج إلى تحليل المستند لاكتشافه، ما قد يؤدي إلى إجراء تحسينات بسيطة في بعض الحالات.
التحميل المسبق لوحدات JavaScript باستخدام حزمة الويب
إذا كنت تستخدم أداة لحزم الوحدات التي تنشئ ملفات إنشاء لتطبيقك، عليك التحقّق ممّا إذا كانت تتيح إدخال علامات التحميل المُسبق. في الإصدار 4.6.0 أو الإصدارات الأحدث من webpack، يمكن استخدام ميزة التحميل المُسبق من خلال استخدام التعليقات السحرية داخل import()
:
import(_/* webpackPreload: true */_ "CriticalChunk")
إذا كنت تستخدم إصدارًا قديمًا من webpack، يمكنك استخدام مكوّن إضافي تابع لجهة خارجية، مثل preload-webpack-plugin.
تأثيرات التحميل المُسبق على "مؤشرات أداء الويب الأساسية"
التحميل المُسبق هو تحسين فعّال للأداء وله تأثير في سرعة التحميل. يمكن أن تؤدي هذه التحسينات إلى تغييرات في مؤشرات أداء الويب الأساسية لموقعك الإلكتروني، ومن المهم أن تكون على دراية بها.
سرعة عرض أكبر محتوى مرئي (LCP)
تؤثر التحميل المُسبق بشكل كبير في سرعة عرض أكبر محتوى مرئي (LCP) في ما يتعلّق بالخطوط والصور، لأنّ كلاً من الصور وعُقد النص يمكن أن تكون مرشحة لـ LCP. يمكن للصور الرئيسية والنصوص الكبيرة التي يتم عرضها باستخدام خطوط الويب أن تستفيد بشكل كبير من تلميح التحميل المسبق الموضوع بشكل جيد، ويجب استخدامها عندما تكون هناك فرص لتقديم هذه الأجزاء المهمة من المحتوى للمستخدم بشكلٍ أسرع.
ومع ذلك، يجب أن تكون حذرًا عندما يتعلق الأمر بالتحميل المسبق — والتحسينات الأخرى! وعلى وجه الخصوص، تجنَّب التحميل المُسبق لعدد كبير جدًا من الموارد. إذا تم إعطاء الأولوية لعدد كبير جدًا من الموارد، فلن يتم ذلك بشكل فعال. وستكون تأثيرات تلميحات التحميل المُسبق الزائدة ضارّة بشكل خاص بتلك التي تستخدم الشبكات البطيئة، حيث يكون التضارب في معدل نقل البيانات أكثر وضوحًا.
بدلاً من ذلك، ركز على بعض الموارد عالية القيمة التي تعرف أنها ستستفيد من التحميل المسبق الموضوع بشكل جيد. عند التحميل المُسبق للخطوط، تأكَّد من عرض الخطوط بتنسيق WOFF 2.0 لتقليل وقت تحميل الموارد قدر الإمكان. بما أنّ WOFF 2.0 متوافق بشكل ممتاز مع المتصفحات، سيؤدي استخدام تنسيقات قديمة مثل WOFF 1.0 أو TrueType (TTF) إلى تأخير سرعة LCP إذا كان مرشح LCP عقدة نصية.
في ما يتعلق بـ LCP وJavaScript، عليك التأكد من إرسال الترميز الكامل من الخادم لكي يعمل ماسح التحميل المسبق في المتصفح بشكل صحيح. إذا كنت تقدّم تجربة تعتمد بشكل كامل على JavaScript لعرض الترميز ولا يمكنك إرسال رمز HTML المعروض من الخادم، سيكون من المفيد الانتقال إلى المكان الذي يتعذّر فيه على الماسح الضوئي للتحميل المسبق في المتصفّح تحميل الموارد التي لا يمكن اكتشافها إلا عند انتهاء تحميل JavaScript وتنفيذه.
متغيّرات التصميم التراكمية (CLS)
يُعدّ متغيّرات التصميم التراكمية (CLS) مقياسًا مهمًا بشكل خاص إذا كانت خطوط الويب معنيّة، كما أنّ متغيّرات التصميم التراكمية (CLS) تتفاعل بشكل كبير مع خطوط الويب التي تستخدم سمة CSS الخاصة بالسمة font-display
لإدارة طريقة تحميل الخطوط. للحدّ من متغيّرات التصميم المتعلقة بخطوط الويب، ننصحك باتّباع الاستراتيجيات التالية:
- يجب تحميل الخطوط مسبقًا مع استخدام القيمة التلقائية
block
فيfont-display
. وهذا توازن دقيق. يمكن أن يُعد حظر عرض الخطوط دون إجراء احتياطي مشكلة في تجربة المستخدم. من ناحية، يؤدي تحميل الخطوط باستخدامfont-display: block;
إلى استبعاد متغيّرات التصميم المرتبطة بخطوط الويب. من ناحية أخرى، ما زلت ترغب في تحميل خطوط الويب هذه في أقرب وقت ممكن إذا كانت ضرورية لتجربة المستخدم. قد يكون الجمع بين التحميل المُسبق وfont-display: block;
حلاً مقبولاً. - يمكنك تحميل الخطوط مسبقًا أثناء استخدام القيمة
fallback
فيfont-display
. يمثّلfallback
حلاً وسطًا بينswap
وblock
، لأنّه لفترة حظر قصيرة جدًا. - استخدِم القيمة
optional
فيfont-display
بدون تحميل مُسبق. إذا لم يكن أحد خطوط الويب عاملاً أساسيًا في تجربة المستخدم، ولكنه لا يزال مُستخدَمًا لعرض قدر كبير من نص الصفحة، ننصحك باستخدام القيمةoptional
. في ظروف معاكسة، سيعرضoptional
نص الصفحة بخط احتياطي أثناء تحميل الخط في الخلفية لعملية التنقّل التالية. يتم تحسين النتيجة الصافية في هذه الشروط من خلال متغيّرات التصميم التراكمية (CLS)، حيث سيتم عرض خطوط النظام على الفور، في حين ستؤدي عمليات تحميل الصفحات اللاحقة إلى تحميل الخط على الفور بدون متغيّرات التصميم.
ومتغيّرات التصميم التراكمية (CLS) هو مقياس يصعب تحسينه عندما يتعلق الأمر بخطوط الويب. كالعادة، يمكنك إجراء التجارب في الميزة الاختبارية، مع ثقتك في البيانات الفعلية التي تستخدمها لتحديد ما إذا كانت استراتيجيات تحميل الخط تحسِّن متغيّرات التصميم التراكمية (CLS) أو تزيد من حدّتها.
مدى استجابة الصفحة لتفاعلات المستخدم (INP)
مدى استجابة الصفحة لتفاعلات المستخدم هو مقياس يقيّم مدى استجابة المستخدمين لإدخاله. وبما أنّ نسبة التفاعل على الويب تكون ناجمة عن JavaScript، قد يساعد التحميل المُسبق لرموز JavaScript التي تشغِّل التفاعلات المهمة في الحفاظ على انخفاض INP للصفحة. ومع ذلك، يجب الانتباه إلى أنّ التحميل المسبق ل الكثير من JavaScript أثناء بدء التشغيل يمكن أن يؤدي إلى عواقب سلبية غير مقصودة إذا كان هناك عدد كبير جدًا من الموارد تتعارض مع معدّل نقل البيانات.
وعليك أيضًا توخي الحذر بشأن كيفية تقسيم الرمز. يُعدّ تقسيم الرموز تحسينًا ممتازًا لتقليل مقدار JavaScript الذي يتم تحميله أثناء بدء التشغيل، ولكن يمكن أن تتأخّر التفاعلات إذا كانت تعتمد على JavaScript الذي تم تحميله في بداية التفاعل مباشرةً. ولتعويض ذلك، ستحتاج إلى فحص نية المستخدم، وإدخال تحميل مسبق للمقطع(المقاطع) الضرورية من JavaScript قبل أن يحدث التفاعل. ومن الأمثلة على ذلك التحميل المُسبق لJavaScript المطلوب للتحقّق من صحة محتوى النموذج عند التركيز على أيّ من الحقول في النموذج.
الخاتمة
لتحسين سرعة الصفحة، عليك تحميل الموارد المهمة التي اكتشفها المتصفّح مسبقًا. قد ينتج عن التحميل المُسبق نتائج عكسية، لذا استخدِم preload
باعتدال وقِس التأثير على أرض الواقع.