Flask și Django sunt cadre de dezvoltare web bazate pe Python. Acest tutorial compară Django vs Flask în detaliu. Flask vs Node este, de asemenea, acoperit pe scurt:
Întotdeauna a fost o dilemă omniprezentă atunci când vine vorba de selectarea unui cadru de lucru pentru următorul proiect. La fiecare câteva luni, vedeți o nouă tehnologie și un cadru de lucru care depășește punctul slab al celui anterior pe care l-ați folosit.
Un cadru este mai degrabă o cultură tăcută și un set de convenții pe care trebuie să le urmați pentru a fi mai relevant și mai productiv în această lume a tehnologiei în continuă schimbare. Comparativ, dezvoltarea web se mișcă mult mai repede decât dezvoltarea desktop.
Django Vs Flask
În acest tutorial, tragem o comparație între Django și Flask în detaliu. Flask și Django sunt cadre de dezvoltare web bazate pe Python. Mulți se îndreaptă spre microframeworks ușoare. Aceste cadre sunt agile, flexibile, mici și ajută la dezvoltarea de microservicii și aplicații fără server.
Având în vedere popularitatea NodeJS, am oferit, de asemenea, o comparație prodigioasă între Flask și Node în secțiunea Flask vs. Node. Evaluarea Django și Flask pe următoarele caracteristici vă va ajuta în alegerea unuia în locul celuilalt.
Administratorul implicit
Ambele framework-uri oferă o aplicație de administrare cu bootstrap. În Django, aceasta este încorporată și vine cu instalarea implicită. Cu toate acestea, în cazul lui Flask, trebuie să instalați Flask-Appbuilder pentru a avea o interfață de administrare.
Între timp, nu uitați să creați un superutilizator în Django și un administrator în cazul Flask, astfel încât să vă puteți conecta la backend-ul de administrare folosind browserul.
Baze de date și ORMS
Django este livrat cu un ORM implicit încorporat care suportă în mod direct interacțiunea cu RDBMS, cum ar fi Oracle, MySQL, PostgreSQL, SQLite etc. Acest ORM suportă, de asemenea, generarea și gestionarea migrărilor. Este relativ mai confortabil să creați modele de baze de date cu validări încorporate.
De asemenea, Flask nu impune o metodă anume și este disponibil pentru a fi folosit cu diverse extensii care suportă caracteristici similare, așa cum am subliniat în cazul Django. Am dat exemple de Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine, într-unul din tutorialele seriei.
Vederi și rute
Ambele framework-uri dispun de mecanisme pentru a declara vizualizări bazate pe metode și vizualizări bazate pe clase. În cazul Django, rutele și vizualizările sunt menționate în fișiere separate. De asemenea, trebuie să transmitem întotdeauna obiectul cererii în mod explicit.
Pe de altă parte, în Flask, putem folosi un decorator pentru a menționa rutele pentru gestionarii corespunzători. Obiectul de cerere în Flask este global și este doar disponibil fără a fi transmis în mod explicit. Am detaliat conceptele de utilizare a vizualizărilor și a rutelor într-unul dintre tutorialele noastre.
Formulare și șabloane
Formularele Django sunt încorporate în framework și nu necesită instalare. Formularele sunt destul de esențiale pentru aplicații, iar în Django, formularele pot fi trecute în tag-uri de șabloane și sunt disponibile pentru a fi redate în șabloane. Cu toate acestea, în cazul Flask, trebuie să folosim Flask-WTF.
De asemenea, am folosit Flask-Appbuilder pentru a crea formulare. În plus, WTF-Alembic poate fi folosit pentru a genera formulare HTML bazate pe modele de baze de date.
Ambele cadre suportă templul Jinja2 și ambele suportă servirea fișierelor statice cu funcții încorporate pentru a genera URL-urile resurselor și este un model destul de comun în toate cadrele din zilele noastre.
Deși există moduri diferite de a trece variabilele și de a reda șabloanele în metodele lor de vizualizare specifice, ambele cadre au aceeași sintaxă de accesare a variabilelor în șabloane.
Flexibilitate
Django, din cauza dimensiunii și complexității sale, este mai puțin flexibil decât Flask. Flask poate fi extins cu ușurință cu ajutorul unui număr mare de extensii pe care le suportă. Prin urmare, este nevoie de mai mult timp și efort pentru a configura Flask, deoarece trebuie să evaluăm mai multe extensii.
Libertatea acordată dezvoltatorilor duce, într-un fel, la o dezvoltare și o livrare mai lentă. Pe de altă parte, Django respectă un set de convenții deja stabilite și urmează arhetipurile care necesită mai puține abateri de la scopurile și obiectivele proiectului.
Curba de învățare
Este nevoie de aproape același timp pentru a învăța atât Django, cât și Flask. Flask are un API mai mic; prin urmare, oamenii ar putea fi capabili să îl termine mai repede în ceea ce privește cadrul de bază. Devine la fel de dificil atunci când vine vorba de utilizarea extensiilor sale. Ar putea deveni greoi în curând.
Cu toate acestea, doar pentru că nu totul este împachetat într-un singur pachet, este mai ușor să practici separarea preocupărilor în cazul cadrului Flask.
Vă recomandăm să învățați modelele și nu sintaxa care este urmată. Atât Django, cât și Flask au o documentație excelentă. O puteți urmări cu ușurință în timp ce dezvoltați o caracteristică.
Dimensiunea și durata proiectului
Când lucrați la un proiect mai mare, cu echipe mai mari, este mai bine să profitați de maturitatea Django și de suportul extins al colaboratorilor. Dacă proiectul dumneavoastră este mai mic și necesită un număr mai mic de dezvoltatori, este mai bine să alegeți Flask.
În plus, dacă proiectul dvs. va dura mult timp, atunci Django este alegerea potrivită; în caz contrar, puteți alege Flask.
Tipul de aplicație
Anterior, Django era considerat a fi alegerea potrivită atunci când exista o cerință pentru aplicații web de nivel enterprise cu drepturi depline. Dar, astăzi, Flask este la fel de matur și poate servi bine în aceleași condiții.
Cu toate acestea, dezvoltatorii tind să aleagă Flask mai mult pentru dezvoltarea de site-uri web mici sau statice, sau pentru implementarea rapidă a serviciilor web RESTful API.
Recrutare de dezvoltatori
Faptul că aveți resurse calificate în convenția cadrului pe care îl folosiți dă roade. Vă puteți aștepta la o dezvoltare mai rapidă, la teste mai rapide, la o livrare mai rapidă și la rezolvarea mai rapidă a problemelor.
Este destul de ușor să găsești noi dezvoltatori în cazul Flask. Cu toate acestea, este o provocare să găsești resurse calificate în Django. Nu sunt mulți dezvoltatori Django gata să fie angajați. În plus, cadrul Django este destul de vechi și, prin urmare, majoritatea noilor angajați sunt scumpi la angajare în comparație cu cei care sunt calificați în cadrul Flask.
Noii absolvenți de studii tehnice preiau, de asemenea, framework-uri ușoare, cum ar fi Flask, deoarece tendințele din industrie se îndreaptă către crearea de aplicații cu microservicii decuplate sau către tehnologia care sprijină crearea implementării fără server. Javascript este utilizat pe scară largă împreună cu framework-urile care sunt mai ușor de utilizat și sunt mai populare.
Sursă deschisă
Atât Flask, cât și Django sunt proiecte open-source. Puteți găsi Django la //github.com/django/django și Flask la //github.com/pallets/flask. Dacă ne uităm la aceste proiecte, numărul de contribuitori la Django este mult mai mare decât cel al contribuitorilor la Flask.
Prin urmare, ne putem aștepta la un suport mai mult și mai rapid dacă avem probleme și întrebări care trebuie rezolvate. Contrar presupunerilor tipice, numărul de utilizatori ai proiectului Flask este mai mare decât cel al proiectului Django.
Un fapt îngrijorător în legătură cu Flask este că s-ar putea să nu existe o extensie stabilă pentru o anumită sarcină. Prin urmare, sarcina de a o filtra pe cea mai bună rămâne în sarcina utilizatorului extensiei.
De exemplu, am folosit Flask-Twitter-oembedder pentru a lucra cu API-ul Twitter în ultimul tutorial, dar această extensie a avut unele probleme din cauza cărora a trebuit să trecem de la Flask-Cache la Flask-Caching.
A trebuit chiar să includem o declarație de instalare personalizată pentru a instala Flask-twitter-oembedder din repo-ul nostru actualizat de pe Github, în loc să îl menționăm în fișierul requrements.txt al proiectului.
Întreținerea frecventă este o provocare tipică cu care vă veți confrunta în cazul unui proiect open-source. Asistența și gestionarea proiectului open-source sunt de obicei legate de servicii plătite. S-ar putea să trebuiască să așteptați mult timp pentru a obține rezolvarea câtorva probleme de la contribuitorii proiectului.
Performanță
Cadrul Flask este mai ușor decât Django și are performanțe mai bune, cu diferențe neglijabile, în special în ceea ce privește operațiunile de I/O.
Aruncați o privire la comparațiile de mai jos. Odată cu creșterea numărului de solicitări, performanța Flask rămâne aproape aceeași. Cu toate acestea, Django are nevoie de mai mult timp pentru a reda șabloanele după ce a preluat date utilizând ORM.
Python Flask Vs Django: O comparație tabelară
# | Caracteristici | Django | Flacon |
---|---|---|---|
1 | Administratorul implicit | Built-in Admin Backend | Instalați Flask-Appbuilder |
2 | Activare Administrare implicită | În settings.py, asigurați-vă că ați descomentat aplicația instalată de administrator. ... # Definiția aplicației INSTALLED_APPS = [ "website", 'django.contrib.admin', # alt cod ] ... | Importați AppBuilder și SQLA din flask_appbuilder, inițializați mai întâi baza de date și apoi Appbuilder. din flask import Flask din flask_appbuilder import AppBuilder, SQLA app=Flask(__name__) db = SQLA(app)appbuilder=AppBuilder(app, db.session) |
3 | Creați un utilizator administrator | python manage.py createsuperuser | flask fab create-admin |
4 | Baze de date și ORMS | ORM încorporat pentru RDBMS Utilizați Django-nonrel pentru backend-uri NoSQL | Instalați Flask-SQLAlchemy O extensie Flask specifică NoSQL, cum ar fi Flask-MongoEngine. |
5 | Vederi și trasee | URLConf în urls.py from django.urls import path din .import views urlpatterns = [ path('/path', views.handler_method), # alte urls și handlers ] | Folosiți decoratorul @app.route("/path") în Vizualizări pentru a corela o rută cu o funcție. @app.route("/path") def handler_method(): # alt cod cu logică suplimentară |
6 | Șabloane de randare | În vizualizări from django.shortcuts import render def example_view(request): tempvar="value_for_template" return render( cerere, 'demo.html', {'tempvar':tempvar} ) | În vizualizări din . import app din flask import request din flask import render_template @app.route("/path") def demo(): tempvar="value_for_template" return render_template( "demo.html", temp_var=temp_var ) |
7 | Interpolare variabilă în șabloane | În templates/demo.html {{ tempvar }} | În templates/demo.html {{ tempvar }} |
8 | Flexibilitate | Mai puțin flexibil | Mai flexibil |
9 | Decizii de proiectare | Mai puține decizii de proiectare cu dezvoltatorii. | Mai multă libertate pentru dezvoltatori. |
10 | Abaterea proiectului | Mai puține abateri de la obiectivele proiectului. | Mai multe abateri datorate libertății acordate dezvoltatorilor. |
11 | Dimensiunea bazei de cod | O bază de cod mai mare | O bază de cod mai mică |
12 | Nr. de API-uri | Mai multe API-uri | Mai puține API-uri |
13 | Tipul de aplicație | Aplicații web cu drepturi depline | Aplicații mai mici / Microservicii |
14 | Aplicații RESTful | Cadrul Django REST pentru aplicații RESTful. | Utilizați următoarele extensii pentru aplicațiile RESTful. Flask-RESTful Flask-RESTX Conexiune |
15 | Performanță | Performanță scăzută atunci când numărul de cereri este mare. | Performanță constantă pe tot parcursul. |
16 | Contribuții Open Source | Un număr mai mare de Forks, Watches și Commits. | Un număr mai mic de Forks, Watches și Commits. |
17 | Dezvoltatorii | Necesită dezvoltatori cu experiență și nu sunt ușor de recrutat. | Majoritatea dezvoltatorilor sunt mai puțin experimentați și se găsesc în număr adecvat. |
Flask Vs Node
În ceea ce privește stiva de dezvoltare web, se pare că dezvoltarea pentru web necesită un amalgam de diverse tehnologii. Trebuie să împărțim o aplicație web în front-end și back-end. Partea de front-end a aplicației este cel mai bine dezvoltată în tehnologiile care rulează în browser, cum ar fi JavaScript, HTML și CSS.
În general, backend-ul este dezvoltat în limbaje adecvate pentru partea de server și poate interacționa cu sistemul de operare de bază, cu bazele de date conectate sau cu rețeaua atunci când este necesar.
Cu toate acestea, un cadru bazat pe JavaScript, numit NodeJS, a schimbat perspectiva de mai sus și a permis dezvoltatorilor să aibă coerență și uniformitate în dezvoltarea front-end și back-end pentru aplicațiile web. Dezvoltatorii puteau dezvolta pentru back-end folosind JavaScript.
În această secțiune Flask vs Node, comparăm Flask, care este un cadru bazat pe limbajul de programare Python, cu Node, care se bazează pe timpul de execuție JavaScript din Chrome, pe baza mai multor criterii, cum ar fi arhitectura, viteza, suportul comunității, etc.
# | Criterii | Flacon | Nod |
---|---|---|---|
1 | Timp de execuție a limbii | Python | Motorul JavaScript V8 din Chrome |
2 | Arhitectură | I/O fără blocare necesită utilizarea unor servere web fără blocare, cum ar fi gunicorn. Categoria Microframework(back end). | Oferă în mod inerent E/S fără blocaj. Categoria Fullstack |
3 | Manager de pachete | pip | npm |
4 | Viteză | Mai lent din cauza unui interpretor Python separat. | Mai rapid datorită compilatorului Just-In-Time. |
5 | Sursă deschisă | Da | Da |
6 | Sprijin comunitar | Pe Github 2.3 Ceasuri K 51.4 K Stele 13.7 K Furci | Pe Github 2.9 K Ceasuri 71.9 K Stele 17.6 K Furci |
7 | Depanare | Mai ușor de depanat cu depanatorul Python fără dependențe. | Necesită mai mult efort. Mai ușor cu un IDE de dezvoltare cu Bluebird / Promise Library. |
8 | Întreținere | Întreținere redusă | Întreținere mai mare |
9 | Aplicații în timp real | În mod inerent, nu este adecvat. Cu toate acestea, poate funcționa împreună cu socket.io pentru cazuri de utilizare în timp real. Utilizați extensia Flask-socketio. | Adecvat datorită arhitecturii bazate pe evenimente și modulelor de streaming. În mod inerent asincron. |
10 | Biblioteci | Mai matură și mai stabilă. | Mai puțin matură și mai puțin stabilă, dar cu dezvoltare activă și versiuni de remediere. |
11 | Calitatea codului | Acesta este creat exclusiv pentru partea din spate. | Aceasta este uneori compromisă din cauza noilor dezvoltatori front-end care trec la back-end. |
12 | Componența echipei de dezvoltatori | Echipele sunt compuse, de obicei, din dezvoltatori back end și dezvoltatori front end. Preocupările sunt separate. | Dezvoltatorii pot face schimb de roluri și pot lucra atât pentru front-end, cât și pentru back-end. |
13 | Integrarea cu sistemele și aplicațiile existente | Mai ușor de integrat cu alte aplicații backend existente, utilizând ecosistemul Python pentru aplicații de învățare automată și aplicații de date mari. | Destul de nou și necesită crearea de biblioteci personalizate sau noi pentru integrarea cu alte aplicații existente. |
Întrebări frecvente
Î #1) Ce ar trebui să învăț mai întâi, Django sau Flask?
Răspuns: Este mai bine să folosiți mai întâi Flask. Odată ce ați dobândit puțină experiență în dezvoltarea web, vă puteți apuca de Django. Django presupune că știți deja cum funcționează aplicațiile web și se ocupă singur de cea mai mare parte a funcționalității.
Î #2) Este Flask sau Django mai bun?
Răspuns: Atât Flask, cât și Django sunt excelente și potrivite pentru scopul lor. Django este folosit pentru a crea aplicații mai proeminente la scară de întreprindere. Flask este folosit pentru a crea aplicații statice și mai mici. Flask este, de asemenea, potrivit pentru prototipuri. Cu toate acestea, cu ajutorul extensiilor Flask, putem crea și aplicații mari.
Î #3) Ce companii folosesc Flask?
Răspuns: Unele dintre companiile care folosesc Flask sunt Reddit, Mailgun, Netflix, Airbnb etc.
Î #4) Ce site-uri folosesc Django?
Răspuns: Unele dintre site-urile care folosesc Django sunt Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite etc.
Concluzie
Nu ar trebui să ne fixăm prea mult timp pe un singur cadru. Ar trebui să fim pregătiți să învățăm noi seturi de tehnologie și să adoptăm stive în tendințe. Unii dintre noi doresc abordări comparative din start, cu baterii incluse, cu cicluri de lansare rigide, menținând o compatibilitate mai strânsă cu trecutul etc.
Dacă credeți că aparțineți mai mult acestui grup, atunci trebuie să alegeți Django. Cu toate acestea, este incredibil să mergeți alături de noile caracteristici și de flexibilitatea cadrului Flask de asemenea. Atunci când doriți să mențineți coerența între front-end și back-end, puteți alege un cadru full-stack, cum ar fi NodeJS.
A alege un cadru este mai mult o alegere care depinde de contextul și de problemele pe care încercăm să le rezolvăm. Selectarea unui cadru este întotdeauna dificilă. Sperăm că am prezentat punctele esențiale de revizuire în acest tutorial și că vă va ajuta în finalizarea unui cadru. Cu toate acestea, vă recomandăm să învățați ambele cadre.
Este mai ușor să începeți cu Flask și apoi să treceți la Django după ce ați dobândit o anumită experiență în dezvoltarea web. Dacă, din anumite motive, eforturile dvs. de dezvoltare necesită utilizarea JavaScript, atunci puteți merge mai departe cu NodeJS.