يعتبر كل من Flask و Django من أطر تطوير الويب المستندة إلى Python. يقارن هذا البرنامج التعليمي بين Django و Flask بالتفصيل. تمت تغطية Flask vs Node أيضًا باختصار:
لقد كانت دائمًا معضلة منتشرة عندما يتعلق الأمر بمسألة اختيار إطار عمل لمشروعك التالي. كل بضعة أشهر ، ترى تقنية جديدة وإطار عمل يتغلب على ضعف التقنية السابقة التي استخدمتها.
إطار العمل يشبه إلى حد كبير الثقافة الصامتة ، ومجموعة من الاصطلاحات التي يجب عليك اتباعها لتكون أكثر ذات صلة ومثمرة في عالم التكنولوجيا المتغير باستمرار. بالمقارنة ، تطوير الويب يتحرك أسرع بكثير من تطوير سطح المكتب.
Django Vs Flask
في هذا البرنامج التعليمي ، قمنا بإجراء مقارنة بين Django و Flask بالتفصيل. يعتبر كل من Flask و Django من أطر تطوير الويب المستندة إلى Python. يتجه الكثيرون نحو الأطر الدقيقة خفيفة الوزن. هذه الأطر رشيقة ومرنة وصغيرة وتساعد على تطوير خدمات صغيرة وتطبيقات بدون خادم.
بالنظر إلى شعبية NodeJS ، قدمنا أيضًا مقارنة رائعة بين Flask و Node ضمن قسم Flask مقابل Node. سيساعدك تقييم Django و Flask على الميزات التالية في اختيار واحدة على الأخرى.
المسؤول الافتراضي
يوفر كلا الإطارين تطبيق إداري تم تشغيله. في Django ، هو مدمج ويأتي مع الافتراضيتمكين المطورين من الاتساق والتوحيد عبر تطوير الواجهة الأمامية والخلفية لتطبيقات الويب. يمكن للمطورين تطوير الواجهة الخلفية باستخدام JavaScript.
في قسم Flask vs Node هذا ، نقارن Flask ، وهو إطار عمل قائم على لغة برمجة Python ، مع Node ، والذي يعتمد على وقت تشغيل JavaScript في Chrome وفقًا لمعايير مختلفة مثل كالعمارة والسرعة ودعم المجتمع وما إلى ذلك.
فئة Microframework (النهاية الخلفية).
فئة Fullstack
2.3 K Watches
51.4 K Stars
13.7 K Forks
2.9 K Watches
71.9 K Stars
17.6 K Forks
الأسئلة المتداولة
Q # 1) ما الذي ينبغي عليّ فعلهالتعلم أولاً ، Django أو Flask؟
الإجابة: من الأفضل استخدام Flask أولاً. بمجرد اكتساب القليل من الخبرة في تطوير الويب ، يمكنك استخدام Django. يفترض Django أنك تعرف بالفعل كيفية عمل تطبيقات الويب ، وأنه يعتني بمعظم الوظائف بنفسه.
Q # 2) هل Flask أو Django أفضل؟
الإجابة: كل من Flask و Django ممتازان ومناسبان لغرضهما. يتم استخدام Django لإنشاء تطبيقات أكثر بروزًا على مستوى المؤسسات. يستخدم Flask لإنشاء تطبيقات ثابتة وأصغر. القارورة مناسبة أيضًا للنماذج الأولية. ومع ذلك ، مع استخدام ملحقات Flask ، يمكننا إنشاء تطبيقات كبيرة أيضًا.
س # 3) ما هي الشركات التي تستخدم Flask؟
الإجابة: بعض الشركات التي تستخدم Flask هي Reddit و Mailgun و Netflix و Airbnb وما إلى ذلك.
Q # 4) ما هي المواقع التي تستخدم Django؟
إجابة : بعض المواقع التي تستخدم Django هي Instagram و Spotify و YouTube و Dropbox و Bitbucket و Eventbrite وما إلى ذلك. . يجب أن نكون مستعدين لتعلم مجموعات جديدة من التكنولوجيا واعتماد مجموعات تتجه هناك. البعض منا يريد نسبيًا خارج الصندوق ، نهجًا متضمنًا للبطارية مع دورات إطلاق صارمة ، والحفاظ على توافق أكثر إحكامًا مع الإصدارات السابقة ، وما إلى ذلك.
إذا كنت تعتقد أنك تنتمي أكثر إلى هذه المجموعة ، فيجب عليك اختيار Django. ومع ذلك ، فهو أمر لا يصدقللمشي جنبًا إلى جنب مع الميزات الجديدة والمرونة في إطار Flask أيضًا. عندما تريد الحفاظ على التناسق بين الواجهة الأمامية والخلفية ، يمكنك اختيار إطار عمل مكدس كامل مثل NodeJS.
يعد استخدام إطار عمل خيارًا يعتمد على السياق والمشكلات التي نحاول القيام بها يحل. اختيار إطار عمل صعب دائمًا. نأمل أن نكون قد قدمنا نقاط المراجعة الأساسية في هذا البرنامج التعليمي ، وسيساعدك في إنهاء إطار عمل واحد. ومع ذلك ، نوصي بتعلم كلا الإطارين.
من الأسهل البدء باستخدام Flask ثم الانتقال إلى Django بعد اكتساب بعض الخبرة في تطوير الويب. إذا كانت جهود التطوير الخاصة بك تتطلب استخدام JavaScript لسبب ما ، فيمكنك المضي قدمًا في NodeJS.
تثبيت. ومع ذلك ، في حالة Flask ، تحتاج إلى تثبيت Flask-Appbuilder للحصول على واجهة مشرف.وفي الوقت نفسه ، تذكر إنشاء مستخدم متميز في Django والمسؤول في حالة Flask حتى تتمكن من تسجيل الدخول إلى admin backend باستخدام المتصفح.
قواعد البيانات و ORMS
يتم شحن Django مع ORM افتراضي مدمج والذي يدعم بشكل مباشر التفاعل مع RDBMS مثل Oracle و MySQL و PostgreSQL و SQLite وما إلى ذلك. يدعم توليد وإدارة الهجرات. من المريح نسبيًا إنشاء نماذج قاعدة بيانات مع عمليات التحقق الداخلية.
لا تفرض Flask أيضًا أي طريقة معينة وهي متاحة للاستخدام مع العديد من الإضافات التي تدعم ميزات مماثلة كما هو موضح في حالة Django. لقد قدمنا أمثلة على Flask-SQLAlchemy و Flask-Migrate و Flask-MongoEngine ، في أحد البرامج التعليمية للسلسلة. وجهات النظر القائمة على الطبقة. في حالة Django ، تم ذكر الطرق والآراء في ملفات منفصلة. أيضًا ، نحتاج دائمًا إلى تمرير كائن الطلب بشكل صريح.
من ناحية أخرى ، في Flask ، يمكننا استخدام مصمم لذكر مسارات المعالجات المقابلة. كائن الطلب في Flask هو عالمي ومتاح فقط دون أي تمرير صريح. لقد قمنا بتفصيل مفاهيم استخدام طرق العرض والطرق في أحد مواقعناالدروس.
النماذج والقوالب
نماذج Django مدمجة في الإطار ولا تتطلب أي تثبيت. تعتبر النماذج ضرورية جدًا للتطبيقات ، وفي Django ، يمكن تمرير النماذج إلى علامات القوالب ، وهي متاحة لتقديمها في قوالب. ومع ذلك ، في حالة Flask ، نحتاج إلى استخدام Flask-WTF.
كما استخدمنا Flask-Appbuilder لإنشاء النماذج. علاوة على ذلك ، يمكن استخدام WTF-Alembic لإنشاء نماذج HTML استنادًا إلى نماذج قاعدة البيانات.
يدعم كلا الإطارين نموذج Jinja2 ، ويدعم كلاهما خدمة الملفات الثابتة بوظائف مضمنة لإنشاء عناوين URL للموارد وهو نمط شائع جدًا في جميع الأطر هذه الأيام.
على الرغم من وجود طرق مختلفة لتمرير المتغيرات وتقديم القوالب في طرق العرض الخاصة بهم ، فإن كلا الإطارين لهما نفس بنية الوصول إلى المتغيرات في القوالب.
المرونة
دجانجو ، بسبب حجمها وتعقيدها الهائل ، أقل مرونة من القارورة. يمكن تمديد Flask بسهولة بمساعدة عدد كبير من الملحقات التي يدعمها. لذلك ، يحتاج إعداد Flask إلى مزيد من الوقت والجهد لأننا بحاجة إلى تقييم المزيد من الامتدادات.
تؤدي الحرية الممنوحة للمطورين بطريقة ما إلى إبطاء التطوير والتسليم. من ناحية أخرى ، يتبع Django مجموعة من الاتفاقيات المعمول بها بالفعل ويتبع النماذج الأصلية التي تتطلب انحرافًا أقلمن أهداف المشروع وغاياته.
منحنى التعلم
يتطلب تقريبًا نفس القدر من الوقت لتعلم كل من Django و Flask. يحتوي Flask على واجهة برمجة تطبيقات أصغر ؛ لذلك ، قد يتمكن الأشخاص من إنهائه بشكل أسرع فيما يتعلق بإطار العمل الأساسي. يصبح الأمر صعبًا بنفس القدر عندما يتعلق الأمر باستخدام امتداداته. قد يصبح الأمر مرهقًا قريبًا.
ومع ذلك ، لمجرد عدم تعبئة كل شيء في حزمة واحدة ، فمن الأسهل ممارسة فصل الاهتمامات في حالة إطار عمل Flask.
نوصي بأن تقوم بذلك تعلم الأنماط وليس الصيغة التي يتم اتباعها. يمتلك كل من Django و Flask وثائق ممتازة. يمكنك متابعته بسهولة أثناء تطوير ميزة.
حجم المشروع ومدته
عندما تعمل في مشروع أكبر مع فرق أكبر ، فمن الأفضل الاستفادة من نضج Django و دعم المساهمين الواسع الذي يتمتع به. إذا كان مشروعك أصغر ويتطلب عددًا أقل من المطورين ، فمن الأفضل استخدام Flask.
علاوة على ذلك ، إذا كان مشروعك سيستمر لفترة طويلة ، فإن Django هو الخيار الصحيح ؛ بخلاف ذلك ، يمكنك تحديد Flask.
نوع التطبيق
كان يعتبر Django سابقًا هو الاختيار الصحيح عندما كان هناك متطلبات لتطبيقات الويب الكاملة على مستوى المؤسسة. ولكن ، أصبح Flask اليوم ناضجًا بنفس القدر ويمكن أن يخدم بشكل جيد نفس الظروف.
ومع ذلك ، يميل المطورون إلىاختر Flask more لتطوير مواقع ويب صغيرة أو ثابتة ، أو أثناء التنفيذ السريع لتقديم خدمات ويب RESTful API.
Developer Recruitment
وجود موارد ماهرة في اتفاقية إطار العمل الذي تستخدمه يؤتي ثماره. يمكنك توقع تطوير أسرع واختبار أسرع وتسليم أسرع وإصلاحات أسرع للمشكلات.
من السهل جدًا العثور على مطورين جدد في حالة Flask. ومع ذلك ، من الصعب العثور على موارد ماهرة في Django. لا يوجد الكثير على استعداد لتوظيفهم من قبل مطوري Django. علاوة على ذلك ، فإن إطار عمل Django قديم جدًا ، وبالتالي ، فإن معظم التعيينات الجديدة باهظة الثمن عند مقارنتها بالذين يتمتعون بالمهارة في إطار Flask.
يلتقط الخريجون الفنيون الجدد أيضًا أطرًا خفيفة مثل كـ Flask لأن اتجاهات الصناعة تتجه نحو إنشاء تطبيقات بخدمات صغيرة منفصلة أو التكنولوجيا التي تدعم إنشاء التنفيذ بدون خادم. تُستخدم Javascript على نطاق واسع مع الأطر الأسهل في الاستخدام والأكثر شيوعًا.
Open Source
كلا Flask و Django هما مشروعان مفتوحان المصدر. يمكنك العثور على Django على //github.com/django/django و Flask على //github.com/pallets/flask. بالنظر إلى هذه المشاريع ، فإن عدد المساهمين في Django أكثر شمولاً من أولئك الذين يساهمون في Flask.
لذلك ، يمكننا أن نتوقع دعمًا أكثر وأسرع إذا كان لدينا بعضالقضايا والاستفسارات التي تحتاج إلى حل. على عكس الافتراضات النموذجية ، فإن عدد مستخدمي مشروع Flask أعلى من عدد مستخدمي مشروع جانغو.
إحدى الحقائق المقلقة حول Flask هي أنه قد لا يكون هناك امتداد ثابت لمهمة معينة. لذلك ، يبقى عمل تصفية الأفضل مع مستخدم الامتداد.
على سبيل المثال ، استخدمنا Flask-Twitter-oembedder للعمل مع واجهة برمجة تطبيقات Twitter في البرنامج التعليمي الأخير ، ولكن كان لهذا الامتداد بعض المشكلات التي اضطررنا إلى التبديل من Flask-Cache إلى Flask-Caching.
حتى أننا اضطررنا إلى تضمين بيان تثبيت مخصص لتثبيت Flask-twitter-oembedder من Github repo المحدث بدلاً من ذلك من ذكره في ملف reqensions.txt الخاص بالمشروع.
الصيانة المتكررة هي تحدي نموذجي ستواجهه في مشروع مفتوح المصدر. عادة ما يرتبط دعم وإدارة المشروع مفتوح المصدر بالخدمات المدفوعة. قد تضطر إلى الانتظار لفترة طويلة لإصلاح بعض المشكلات من المساهمين في المشروع.
الأداء
إطار عمل Flask أخف من Django ، ويعمل بشكل أفضل مع اختلافات ضئيلة ، خاصة أثناء التفكير في عمليات الإدخال / الإخراج.
إلقاء نظرة على المقارنات الواردة أدناه. مع زيادة الطلبات ، يظل أداء Flask كما هو تقريبًا. ومع ذلك ، يستغرق Django وقتًا أطول لعرض القوالب بعد جلب البيانات باستخدام امتدادORM.
Python Flask Vs Django: A Tabular Comparison
# | الميزات | Django | Flask |
---|---|---|---|
1 | المسؤول الافتراضي | الواجهة الخلفية للمسؤول المدمج | تثبيت القارورة -Appbuilder |
2 | تمكين المسؤول الافتراضي | في settings.py ، تأكد من إلغاء التعليق على التطبيق المثبت من قبل المسؤول. ... # تعريف التطبيق INSTALLED_APPS = [ 'website'، 'django.contrib.admin'، # other كود ] ... | استيراد AppBuilder و SQLA من flask_appbuilder ، قم بتهيئة DB أولاً ثم Appbuilder من flask import Flask من flask_appbuilder import AppBuilder ، SQLA app = Flask (__ name__) db = SQLA (app) appbuilder = AppBuilder (app، db.session) |
3 | إنشاء مستخدم إداري | python management.py createuperuser | flask fab create-admin |
4 | قواعد البيانات و ORMS | ORM يحمل في ثناياه عوامل لـ RDBMS استخدم Django-nonrel لخلفيات NoSQL | تثبيت Flask-SQLAlchemy A NoSQL ملحق Flask محدد مثل Flask-MongoEngine |
5 | المشاهدات والمسارات | URLConf في urls.py من django مسار استيراد عناوين URL من طرق عرض الاستيراد. والمعالجات ] | استخدم مصمم @ app.route ("/ path") على طرق العرض لتعيين مسار باستخدامدالة. @ app.route (“/ path”) def handler_method (): # كود آخر مع منطق إضافي |
6 | عرض القوالب | في طرق العرض من django.shortcuts استيراد تصيير def example_view (request): tempvar = " value_for_template ” إرجاع العرض ( طلب ، 'demo.html' ، {'tempvar': tempvar} ) | في طرق العرض من. استيراد التطبيق من طلب استيراد flask من flask import render_template @ app.route (“/ path”) def demo (): tempvar = ”value_for_template” إرجاع render_template ( “demo.html” ، temp_var = temp_var ) |
7 | الاستيفاء المتغير في القوالب | في القوالب / demo.html {{tempvar}} | في القوالب / demo.html {{tempvar}} |
8 | المرونة | أقل مرونة | أكثر مرونة |
9 | قرارات التصميم | قرارات تصميم أقل مع المطورين. | المزيد من الحرية للمطورين. |
10 | انحراف المشروع | انحراف أقل عن أهداف المشروع. | مزيد من الانحراف بسبب الحرية الممنوحة للمطورين. |
11 | Size of Codebase | أكبر Codebase | Smaller Codebase |
12 | عدد واجهات برمجة التطبيقات | المزيد من واجهات برمجة التطبيقات | أقل من واجهات برمجة التطبيقات |
13 | نوع التطبيق | تطبيقات الويب المدمجة الكاملة | تطبيقات أصغر /Microservices |
14 | RESTful Applications | إطار عمل Django REST للتطبيقات RESTful. | استخدم الامتدادات التالية لتطبيقات RESTful. Flask-RESTful Flask-RESTX Connexion |
15 | الأداء | بطء الأداء عندما يكون عدد الطلبات كبيرًا. | أداء ثابت طوال الوقت. |
16 | مساهمات المصدر المفتوح | رقم أكثر عدد الشوكات والساعات والالتزامات. | عدد أقل من الشوك والساعات والالتزامات. |
17 | المطورون | تتطلب مطورين ذوي خبرة وليست متاحة بسهولة للتجنيد. | معظم المطورين أقل خبرة ويتواجدون بأعداد كافية. |
Flask Vs Node
فيما يتعلق بمكدس تطوير الويب ، اتضح أن التطوير للويب يتطلب اندماجًا لتقنيات مختلفة. نحتاج إلى تقسيم تطبيق الويب إلى واجهة أمامية وخلفية. يتم تطوير الجزء الأمامي من التطبيق بشكل أفضل في التقنيات التي تعمل في المتصفح ، مثل JavaScript و HTML و CSS.
بشكل عام ، تم تطوير الواجهة الخلفية بلغات مناسبة للخادم- يمكن أن يتفاعل مع نظام التشغيل الأساسي ، أو قواعد البيانات المتصلة ، أو الشبكة عند الحاجة.