دمج ميزانيات الأداء في عملية الإنشاء

بعد تحديد ميزانية أداء، حان وقت إعداد عملية الإنشاء لتتبّعها. هناك عدد من الأدوات التي تتيح لك تحديد الحدود القصوى لمقاييس الأداء المحدّدة وتحذيرك في حال تجاوزت الميزانية. تعرَّف على كيفية اختيار الطريقة التي تناسب احتياجاتك وإعداداتك الحالية على أفضل وجه. 🕵️‍♀️

Lighthouse هي أداة تدقيق تختبر المواقع الإلكترونية في بضعة مجالات رئيسية، مثل الأداء وسهولة الاستخدام وأفضل الممارسات ومستوى أداء موقعك الإلكتروني كتطبيق ويب تقدّمي.

يتيح إصدار سطر الأوامر من Lighthouse (الإصدار 5 والإصدارات الأحدث) ضبط ميزانيات الأداء استنادًا إلى:

  • حجم المرجع
  • عدد الموارد

يمكنك ضبط ميزانيات لأيّ من أنواع الموارد التالية:

  • document
  • font
  • image
  • media
  • other
  • script
  • stylesheet
  • third-party
  • total

يتمّ ضبط الميزانيات في ملف JSON، وبعد تحديدها، يُعلمك عمود "تجاوز الميزانية" الجديد ما إذا كنت تتجاوز أيّ حدود.

قسم "الميزانيات" في تقرير Lighthouse
قسم "الميزانيات" في تقرير Lighthouse

تلميحات حول أداء Webpack

Webpack هي أداة إنشاء فعّالة لتحسين طريقة عرض الرمز البرمجي للمستخدمين. ويتيح أيضًا ضبط ميزانيات الأداء استنادًا إلى حجم مادة العرض.

فعِّل ملاحظات الأداء في webpack.config.js للحصول على تحذيرات أو أخطاء في سطر الأوامر عندما يزداد حجم الحِزمة عن الحدّ المسموح به. وهي طريقة رائعة لتذكُّر أحجام مواد العرض طوال عملية التطوير.

بعد خطوة الإنشاء، يعرض webpack قائمة بمواد العرض وأحجامها مُصنَّفة حسب اللون. يتم تمييز أيّ محتوى يتجاوز الميزانية باللون الأصفر.

تمييز إخراج Webpack لحِزمة bundle.js
إنّ ملف bundle.js المميّز أكبر من ميزانيتك

الحدّ الأقصى التلقائي لكلّ من مواد العرض ونقاط الدخول هو 250 كيلوبايت. يمكنك ضبط استهدافاتك الخاصة في ملف الإعداد.

تحذير بشأن حجم حِزمة Webpack
تحذير بشأن حجم حِزمة Webpack ⚠️

تتم مقارنة الميزانيات بأحجام مواد العرض غير المضغوطة. يرتبط حجم JavaScript غير المضغوطة بوقت التنفيذ، ويمكن أن يستغرق تنفيذ الملفات الكبيرة وقتًا طويلاً، خاصةً على الأجهزة الجوّالة.

اقتراح لتحسين أداء Webpack
الميزة الإضافية: لن يرسل إليك webpack تحذيرًا فقط، بل سيقدّم لك اقتراحًا حول كيفية تقليل حجم الحِزم. 💁

Bundlesize

Bundlesize هي حزمة npm بسيطة تختبر حجم مواد العرض مقارنةً بحدّ أقصى حدّدته. ويمكن تشغيله على الجهاز ودمجه مع عملية التطوير المتكامل (CI).

أداة سطر الأوامر Bundlesize

يمكنك تشغيل bundlesize CLI من خلال تحديد حدّ أدنى والملف الذي تريد اختباره.

bundlesize -f "dist/bundle.js" -s 170kB

يعرض Bundlesize نتائج الاختبار المُصنَّفة حسب اللون في سطر واحد.

تعذُّر اجتياز اختبار سطر أوامر bundlesize
عدم اجتياز اختبار bundlesize في واجهة سطر الأوامر ❌
اجتياز اختبار سطر أوامر bundlesize
اجتياز اختبار bundlesize في واجهة سطر الأوامر ✔️

حجم الحزمة لميزة "التكامل المستمر"

ستحصل على أكبر قيمة من bundlesize إذا دمجتها مع عملية دمج مستمر (CI) لفرض حدود الحجم تلقائيًا على طلبات سحب الرمز البرمجي. إذا تعذّر اختبار حجم الحِزمة، لن يتم دمج طلب سحب هذا الإصدار. ويمكن استخدامه مع طلبات السحب على GitHub باستخدام Travis CI وCircleCI وWercker وDrone.

حالة التحقّق من حجم الحزمة على GitHub
حالة التحقّق من حجم الحِزمة على GitHub

قد يكون لديك تطبيق سريع اليوم، ولكن يمكن أن تؤدي إضافة رمز جديد إلى تغيير ذلك في كثير من الأحيان. سيساعدك التحقّق من طلبات سحب البيانات باستخدام حجم الحِزمة في تجنُّب حدوث تراجع في الأداء. تستخدم Bootstrap وTinder وTrivago وغيرها الكثير من الشركات هذه الميزة للتحقّق من ميزانياتها.

باستخدام bundlesize، من الممكن ضبط الحدود القصوى لكل ملف بشكل منفصل. ويُعدّ ذلك مفيدًا بشكل خاص إذا كنت بصدد تقسيم حِزمة في تطبيقك.

وبشكلٍ تلقائي، يختبر أحجام مواد العرض المضغوطة بتنسيق gzip. يمكنك استخدام خيار الضغط للتبديل إلى ضغط brotli أو إيقافه تمامًا.

روبوت Lighthouse

روبوت Lighthouse

يتكامل Lighthouse Bot مع Travis CI ويفرض الميزانيات استنادًا إلى أيّ من فئات تدقيق Lighthouse الخمس. على سبيل المثال، ميزانية بقيمة 100 لنتيجة أداء Lighthouse في بعض الأحيان، يكون من الأسهل تتبُّع رقم واحد بدلاً من ميزانيات مواد العرض الفردية، وتأخذ نتائج Lighthouse في الاعتبار العديد من العوامل.

نتائج Lighthouse 💯
نتائج Lighthouse 💯

يُجري برنامج Lighthouse Bot عملية تدقيق بعد نشر موقع إلكتروني على خادم الاختبار. في .travis.yml، يمكنك ضبط ميزانيات لفئات معيّنة في Lighthouse باستخدام الخيارات --perf أو --a11y أو --bp أو --seo أو --pwa. احرص على البقاء في المنطقة الخضراء بتسجيل نتائج لا تقل عن 90.

after_success:
  - ./deploy.sh # Deploy the PR changes to staging server
  - npm run lh -- --perf=96 https://staging.example.com # Run Lighthouse test

إذا كانت نتائج طلب سحب على GitHub أقل من الحدّ الأدنى الذي حدّدته، يمكن أن يمنع Lighthouse Bot دمج طلب السحب. ⛔

التحقّق من حالة برنامج التتبُّع Lighthouse على GitHub
حالة التحقّق من برنامج Lighthouse Bot على GitHub

بعد ذلك، ينشر Lighthouse Bot تعليقات على طلب السحب مع النتائج المعدَّلة. هذه ميزة رائعة تشجع على إجراء محادثة حول الأداء أثناء إجراء تغييرات على الرمز البرمجي.

تقارير Lighthouse عن النتائج في طلب سحب
نتائج إعداد تقارير Lighthouse في طلب سحب 💬

إذا تبيّن لك أنّ طلب سحب الرمز البرمجي قد تم حظره بسبب نتيجة ضعيفة في Lighthouse، يمكنك إجراء عملية تدقيق باستخدام Lighthouse CLI أو في أدوات المطوّرين. وتنشئ هذه الأداة تقريرًا يتضمّن تفاصيل عن نقاط الضعف واقتراحات لتحسينات بسيطة.

ملخّص

الأداة CLI كوت ديفوار ملخّص
منارة ✔️
  • ميزانيات لأنواع مختلفة من الموارد استنادًا إلى حجمها أو عددها
webpack ✔️
  • الميزانيات المستندة إلى أحجام مواد العرض التي أنشأها webpack
  • التحقّق من الأحجام غير المضغوطة
bundlesize ✔️ ✔️
  • الميزانيات المستندة إلى أحجام موارد معيّنة
  • التحقّق من الأحجام المضغوطة أو غير المضغوطة
روبوت Lighthouse ✔️
  • الميزانيات المستندة إلى نتائج Lighthouse