Rails هو إطار عمل متوافق مع Rails يركز على تطوير التطبيقات السريعة. لسوء الحظ، غالبًا ما يتسبب نهج "كل شيء خارج الصندوق" والسلوك الأعمى لطريقة Rails في كثير من الأحيان في فقدان جودة كود التطبيق، سواء من حيث استقباله (سهولة القراءة) أو التشغيل.
مشاكل القضبان وريلز-واي الشائعة
- التوجيه,
- قبل الإجراءات,
- إجراءات كبيرة في وحدات التحكم,
- الطرق الخاصة في وحدات التحكم,
- المخلوطات المستخدمة مرة واحدة,
- المنطق في المشاهدات,
- استدعاءات ActiveRecord الاسترجاعات,
- الجمعيات,
- "العارضات البدينات"
مشاكل إضافية
- عمليات التحقق من صحة السجل النشط,
- الضمني على الصريح,
- إساءة استخدام جاف,
- الوفود إلى الجمعيات,
- مكالمات الخدمة في النماذج.
بدائل القضبان
عندما يتعلق الأمر ب القضبان في روبي العالم، لدينا العديد من البدائل. تشمل الأطر الأخرى القائمة على Rack ما يلي: - سيناترا, – روضة, – هانامي.
ما الذي يجعلها فريدة من نوعها؟
يقدم لنا كل من Sinatra و Roda بناء جملة توجيه كتلة، لكن التوجيه في Sinatra عبارة عن قائمة وفي Roda - شجرة. في كلا الإطارين، علينا التعامل مع تنفيذ طبقة النموذج بأنفسنا. في حالة Roda، من الجيد استخدام جوهرة Sequel.
رودا مستوحى من سيناترا. إنه خفيف جداً في حد ذاته، ولكنه يحتوي على الكثير من الإضافات.
هانامي هو الأقرب إلى القضبان عندما يتعلق الأمر بالمجالات التي يغطيها الإطار. وأهم الاختلافات من حيث الاستخدام هي:
- وحدات التحكم في القضبان مقابل الأفعال في هانامي
- فئات/كائنات مخصصة للتعامل مع طلب HTTP معين، وليس وحدة تحكم واحدة للإجراءات المتعلقة بمورد معين (نموذج),
- طبقة نموذجية تعتمد على المستودعات والكيانات، وتفصل الثبات عن بقية التطبيق، وليس نمط السجل النشط.
يحدّ الإصدار 1 من Hanami بشدة من استخدام ROM الذي يستند إليه (الإصدار 3، وهو بالفعل 5)، لذلك لا يستحق استخدام طبقة النموذج المقترحة هناك. ومع ذلك، نظرًا لأنه إطار مفتوح للغاية، فمن السهل جدًا تنفيذ النموذج الخاص بك هناك.
مكملات القضبان
من المفيد استخدام حلول لا تعتمد على القضبان وأقرب إلى "النقاء" روبي. الأدوات المذكورة في العرض التقديمي هي:
- Sequel (ORM، بديل لـ ActiveRecord),
- ذاكرة القراءة فقط (راسم خرائط الكائنات),
- مكتبات Dry-rb: التحقق الجاف، والنظام الجاف، والوحيد الجاف.
من السهل وضع التكملة في المشروعفهو يعتمد على المكونات الإضافية وينفذ أيضًا نمط السجل النشط. لديه دعم استعلام منخفض المستوى أفضل من القضبان' أكتيف ريكورد.
يستخدم ROM Sequel، لكن مفهومه هو الترجمة بين السجلات في قاعدة (قواعد) البيانات و روبي الكائنات. يهدف إلى السرعة وتحويل البيانات. يفصل بوضوح طبقة المثابرة في التطبيق.
المكتبات الجافة-رب هي أدوات مفيدة للغاية:
- من السهل جدًا استخدام التحقق الجاف في مشاريع واجهة برمجة التطبيقات (API) ويسمح بتحكم كبير في صحة البيانات الواردة,
- يحتاج النظام الجاف إلى القليل من الصبر والصبر على المطورين لفهمه، لكنه يسمح بإدارة مرنة جدًا للتبعيات في التطبيق وتحميل مكونات المشروع بشكل منفصل؛ إذا أردنا استخدام هذه المكتبة في القضبان، يمكننا استخدام القضبان الجافة,
- تعد الموناد الجافة مفهومًا صعبًا من الناحية النظرية، ولكن من الناحية العملية من السهل فهمه، يمكن أن تكون الموناد النتيجة طريقة رائعة لزيادة سهولة قراءة الكود من خلال النظر في حالات محددة بدلًا من تفرع الحالات.
الاستنتاجات
من الأفضل استخدام القضبان بحيث لا تضطر إلى استخدام القضبان يوم واحد.
المصادر
المقالات
أطر العمل
الأحجار الكريمة
المواصفات
اقرأ المزيد:
ما هو Ruby on Jets وكيفية إنشاء تطبيق باستخدامه؟
Vuelendar. مشروع كودست جديد يستند إلى Vue.js
تقرير كودست الأسبوعي لأفضل المقالات التقنية. بناء برمجيات لـ 50 مليون مقبس متزامن (10)