Angular هو إطار عمل تطبيقات الويب مفتوح المصدر الرائد من Google المصمم لتطوير تطبيقات فعالة ومتطورة من صفحة واحدة (SPAs). إنها منصة تطوير مشتركة قادرة على إنشاء تطبيقات ويب تقدمية حديثة وتطبيقات محمولة وسطح مكتب عبر Mac و Windows و Linux. بصرف النظر عن نظامها البيئي القوي للتطوير ، توفر Angular هيكلا نظيفا خارج الصندوق يمكن المطورين من اتباع أنماط التصميم لبناء المشاريع وتوسيع نطاقها وصيانتها. يتيح ذلك للمطورين مزج المكونات ومطابقتها بسهولة ، مما ينتج عنه تصميم تطبيق سلس مع مكونات منفصلة.

ومع ذلك ، فإن كتابة التعليمات البرمجية فقط لإنشاء تطبيق Angular يمكن أن يؤدي لاحقا إلى مشكلات في الأداء وأوقات تحميل بطيئة. إن العمل مع أحدث الميزات من إطار العمل وإعادة تنظيم بنية المشروع والملفات والتعليمات البرمجية بجد ليست سوى عدد قليل من الإجراءات التي ينفذها المطورون لتحسين الأداء العام. تتطلب التوقعات العالية اليوم لأوقات التحميل بسرعة البرق من المطورين الانتباه إلى مجالات أخرى ، مثل وقت الإنشاء والنشر ، وتقنيات تحسين التعليمات البرمجية ، والاستراتيجيات التشغيلية لمراقبة مقاييس التطبيق أثناء وقت التشغيل من أجل تحسين أداء التطبيقات.

 

مشكلات عند تحديد أداء التطبيق وأوقات التحميل

نظرا لأن Angular هو إطار عمل حديث قائم على الكتابة المطبوعة يوفر صفحات ويب ديناميكية ، فإنه يوفر بعض التحديات في مراقبة أدائه ووقت التحميل. من المزعج القياس بدقة عند عرض محتوى جديد على الصفحة لأن SPA لا تؤدي إلى تنقل جديد في المتصفح بمجرد تحميل صفحة الويب. لذلك ، لن توفر أدوات مراقبة HTTP (وكذلك أدوات مراقبة API) مقاييس مهمة لتحسين أوقات التحميل نظرا لأن Angular لا يؤدي إلى تشغيل طلبات متصفح جديدة إلى الخادم.

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

 

أدوات لتحسين أوقات التحميل

يقدم Angular قائمة بالأدوات والتقنيات التي يمكن أن تساعد في تقليل وقت تحميل التطبيق ومراقبة أدائه بمرور الوقت ، خاصة بعد توسيع نطاق التطبيق بما يكفي للتعامل مع العديد من الحسابات الثقيلة. بعض هذه التقنيات التي يمكن أن تساعد في تقليل وقت التحميل الأولي للتطبيق وتسريع التنقل في الصفحة هي وحدات التجميع المسبق (AoT) وتقسيم التعليمات البرمجية والتحميل المسبق. سنناقش هذه التقنيات بمزيد من التفصيل.

تجميع مبكر

هناك طريقتان رئيسيتان لتجميع تطبيق Angular: Just-in-Time (JiT) ، الذي يجمع التطبيق في متصفح الويب في وقت التشغيل و Ahead-of-Time (AoT) ، والذي كما ينص الاسم ، يقوم بتجميع التطبيق في وقت الإنشاء. يقوم مترجم AoT بتجميع التعليمات البرمجية ل HTML و TypeScript أثناء عملية الإنشاء قبل أن يقوم متصفح الويب بتنزيلها.

يساعد على تسريع عملية العرض عن طريق تقليل الوقت الذي يستغرقه التطبيق للتمهيد بشكل كبير. بهذه الطريقة ، يقوم متصفح الويب بتحميل التعليمات البرمجية القابلة للتنفيذ مما يسمح له بعرض التطبيق على الفور دون الحاجة إلى انتظار تجميع التطبيق. علاوة على ذلك ، تقلل التعليمات البرمجية المترجمة مسبقا من عدد الطلبات غير المتزامنة إلى مصادر خارجية عن طريق إضافة هذه الموارد ، مثل قوالب HTML و CSS الخارجية ، داخل التطبيق. وبالتالي ، فإن التعليمات البرمجية المترجمة تخفف من طلبات AJAX المنفصلة لتلك الملفات. لذلك ، تصبح تجربة المستخدم أكثر سلاسة وأسرع.

 

تقسيم التعليمات البرمجية

باختصار ، يفصل تقسيم التعليمات البرمجية حزم JavaScript الخاصة بالتطبيق بطريقة لا تخاطر بميزات التطبيقات. يحافظ على التحكم في شفرة جافا سكريبت الرئيسية أثناء وقت التحميل الأولي. يمكن إجراء تقسيم التعليمات البرمجية على مستويات مختلفة داخل التطبيق ، مثل نقاط الدخول والوحدات النمطية المحملة ديناميكيا والتعليمات البرمجية المشتركة بمساعدة SplitChunksPlugin مع منع تكرار التعليمات البرمجية.

هناك طريقتان رئيسيتان لتقسيم التعليمات البرمجية في تطبيق Angular: تقسيم التعليمات البرمجية على مستوى المكون وتقسيم التعليمات البرمجية على مستوى المسار. يتمثل الاختلاف الرئيسي بين النهجين في أن تقسيم التعليمات البرمجية على مستوى المكون يحمل المكونات الفردية بتكاسل ، حتى بدون التنقل في المسار ، بينما يقوم تقسيم التعليمات البرمجية على مستوى المسار بتحميل المسارات الفردية بتكاسل. على أي حال ، يمكن اختبار كلا النهجين بالنظر إلى TTI (وقت التفاعلية) الخاص بالتطبيق. TTI هو مؤشر أداء رائع للمقارنة لأنه يقيس مقدار الوقت الذي يستغرقه التطبيق ليكون مستجيبا. بمعنى آخر ، كم من الوقت يستغرق تحميل التطبيق حتى يتمكن المستخدم من التفاعل معه.

 

وحدات التحميل المسبق

وحدات التحميل المسبق هي تقنية مقدمة في تطبيقات Angular تسمح بتحميل الوحدات في أقرب وقت ممكن باتباع القواعد المعمول بها. يمكن تحميل الوحدات مسبقا في نفس الوقت ، عند وقوع حدث معين أو مجرد عدد قليل محدد حسب الظروف. يتمتع المطورون بإمكانية التحقق من مقدار الوقت الذي يستغرقه تحميل الوحدة والقيمة الكامنة لاستخدام استراتيجية التحميل المسبق. تشبه وحدات التحميل المسبق في Angular إلى حد كبير التحميل البطيء باستثناء أنه يتم تحميل وحدات التطبيقات مباشرة بعد تحميل جميع الوحدات المحملة المتحمسة بنجاح. بهذه الطريقة ، يتم تجاهل زمن الانتقال المحتمل عندما ينتقل المستخدم إلى وحدة نمطية محملة بطيئة مع الاستمرار في الاستفادة من التحميل الأولي الأسرع للتطبيق لأنه يتم تحميل وحداته الأولية أولا.

استراتيجيات التحميل المسبق الافتراضية ل Angular هي PreloadAllModules و NoPreloading. الأول يعني أن جميع الوحدات القابلة للتحميل البطيئة يتم تحميلها مسبقا بينما يقوم الأخير بتعطيل أي تحميل مسبق. في حالة استخدام PreloadAllModules ، من المحتمل أن تواجه التطبيقات عنق الزجاجة إذا كان التطبيق يحتوي على عدد كبير من الوحدات. عندها عند التفكير في استراتيجية التحميل المسبق المخصصة يمكن أن تكون مفيدة.

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

 

تحميل اختبار التطبيقات الزاوية الخاصة بك مع LoadView

يقترح LoadView حلا مبتكرا وشاملا للتعامل مع قيود أدوات مراقبة HTTP وتعزيز الأدوات التي يمتلكها مطورو Angular اليوم للتحكم في تطبيقاتهم ومراقبتها وتحسينها من جانب العميل. LoadView عبارة عن نظام أساسي لاختبار التحميل قائم على السحابة يوفر مراقبة اختبار الإجهاد لمواقع الويب وتطبيقات الويب وواجهات برمجة التطبيقات من خلال محاكاة الآلاف من الاتصالات المتزامنة في الوقت الفعلي ، مما يساعد على تحديد الاختناقات والتحقق من الأداء العام.

بعد إنشاء حساب ، يمكن للمطورين اختبار مواقع الويب وتطبيقات الويب الخاصة بهم عن طريق إنشاء جهاز يخزن موقع الويب أو التطبيق المراد اختباره. من خلال اختيار خيار موقع الويب ، يمكن لمطوري Angular اختبار وقت التحميل الأولي لصفحة الهبوط أو تسجيل الدخول الخاصة بتطبيقهم عن طريق تكوين سيناريو يحاول فيه آلاف المستخدمين الوصول إلى الصفحة بشكل متزامن. من ناحية أخرى ، من خلال اختيار خيار تطبيق الويب ، يمكن لمطوري Angular برمجة واختبار وقت التحميل لحالات استخدام محددة لتطبيقاتهم.

على سبيل المثال ، ملء نموذج ، والتنقل عبر المسارات داخل التطبيق ، وفرز البيانات المحملة من الخادم ، وبشكل عام ، قياس TTI لتطبيقهم. يتيح LoadView للمستخدمين تخصيص نوع تحميل الاختبار الخاص بهم بثلاث طرق مختلفة جنبا إلى جنب مع خطة التنفيذ التي تقوم بإعداد عدد الاتصالات التي يجب إنشاؤها خلال فترة. بالإضافة إلى ذلك ، يأخذ LoadView خطوة إلى الأمام من خلال إمكانية ترتيب التوزيع الجغرافي للمستخدمين الافتراضيين المتصلين بالموقع.

يوفر LoadView للمهندسين طريقة فعالة وفعالة من حيث التكلفة لأتمتة عملية اختبار الحمل مقارنة بالطرق التقليدية. لا مزيد من الاستثمارات المكلفة والعمليات التي تستغرق وقتا طويلا. لا داعي للقلق بشأن المطورين والمختبرين بشأن البقاء ضمن الميزانيات المخصصة وإنشاء البنية التحتية. يمكنهم التركيز على ما يفعلونه بشكل أفضل ، وهذا هو تنفيذ الاختبارات. من خلال الاختبار الحقيقي المستند إلى المستعرض، يتم ربط النتائج والرؤى مباشرة برحلات المستخدم، مما يضمن أن تطبيقاتك يمكنها تحمل سيناريوهات ذروة الحمل.

أخيرا ، يتمتع LoadView بالقدرة على عرض تقارير متعمقة كاملة لنتائج المحاكاة. يمكن أن يعرض تمثيلا رسوميا لخطة تنفيذ السيناريوهات لإنشاء اتصالات المستخدم الظاهرية ، ومتوسط وقت الاستجابة لكل مستخدم وعدد الأخطاء لكل جلسة حدثت أثناء تنفيذ السيناريو. تتيح هذه المخططات وبيانات الأداء الفرصة للنظر في معلومات مفصلة عن لحظة معينة من المحاكاة للحصول على نظرة ثاقبة مهمة حول وقت تحميل كل عنصر تم تقديمه إلى الصفحة. هذا مفيد للغاية لتطبيقات Angular لأنه يسمح للمطورين باتخاذ إجراءات بشأن عناصر محددة قد تؤخر TTI للتطبيق. بهذا المعنى ، يملأ LoadView هذا الفراغ في اختبار أحداث JavaScript ومراقبتها بدقة لاختبار وقت التحميل من جانب العميل ، وبالتالي يصبح أصلا قويا يجب أن يمتلكه مطورو الواجهة الأمامية تحت حزامهم.

 

الخلاصة: أداء تطبيق الويب الزاوي

ترفع الطلبات الحالية المستوى من حيث الأداء لتطبيقات الويب الحديثة. يجب أن تضع فرق DevOps اليوم في اعتبارها أن أوقات استجابة التطبيقات و TTI للتطبيق تصبح عاملا محوريا للتطبيقات الجديدة للحصول على فرصة للمنافسة في السوق. في أكثر الأحيان ، يجب على مطوري Angular تقييم تقنيات تقليل وقت التحميل باستمرار مثل تجميع AoT وتقسيم التعليمات البرمجية واستراتيجيات التحميل المسبق عند تصميم التطبيقات ، وكذلك اتخاذ خطوة إلى الأمام. قم باختبار ومراقبة العمليات والمقاييس من جانب العميل باستمرار باستخدام LoadView لضمان أفضل تجربة للمستخدم وأداء للتطبيق.

لمزيد من المعلومات ، قم بزيارة موقع LoadView على الويب وقم بالتسجيل للحصول على الإصدار التجريبي المجاني. ستتلقى ما يصل إلى 5 اختبارات تحميل مجانية لمساعدتك على البدء.

 

مراقبة تطبيقات الويب الزاوية

لأداء ما بعد النشر لتطبيقات Angular الخاصة بك ، تأكد من مراجعة موقعنا على الويب وحل مراقبة تطبيقات الويب ، Dotcom-Monitor. يأتي حل Dotcom-Monitor مع جميع الميزات والفوائد التي تحتاجها لمراقبة تطبيقات الويب Angular الخاصة بك ، مثل المتصفحات الحقيقية والتنبيهات في الوقت الفعلي وتقارير الأداء ولوحات المعلومات ، وبالطبع مسجل الويب EveryStep للمساعدة في مراقبة خطوات المستخدم والمعاملات الهامة. والأفضل من ذلك ، يمكن نقل البرامج النصية التي تم تسجيلها لاختبار التحميل لتطبيقات الويب Angular الخاصة بك إلى منصة المراقبة ، لذلك ليست هناك حاجة لإعادة تسجيل البرامج النصية. يستخدم الحلان نفس الواجهة ، لذا فإن الارتداد بين كلا الحلين سهل وسهل. جرب مراقبة تطبيق الويب لتطبيقات Angular الخاصة بك مجانا.