Django vs Flask vs Node: Milline raamistik valida

Flask ja Django on Pythonil põhinevad veebiarenduse raamistikud. Selles õpetuses võrreldakse üksikasjalikult Django vs Flask. Flask vs Node on ka lühidalt käsitletud:

See on alati olnud läbiv dilemma, kui tuleb küsimus raamistiku valimisest oma järgmise projekti jaoks. Iga paari kuu tagant näed uut tehnoloogiat ja raamistikku, mis ületab eelmise kasutatud raamistiku nõrkuse.

Raamistik on pigem nagu vaikiv kultuur ja konventsioonide kogum, mida peate järgima, et olla selles pidevalt muutuvas tehnoloogiamaailmas asjakohasem ja produktiivsem. Võrreldes sellega liigub veebiarendus palju kiiremini kui töölauaarendus.

Django vs Flask

Selles õpiobjektis joonistame üksikasjalikult välja Django ja Flaski võrdluse. Flask ja Django on Pythonil põhinevad veebiarenduse raamistikud. Paljud on liikumas kergete mikroraamistike suunas. Need raamistikud on agiilsed, paindlikud, väikesed ja aitavad arendada mikroteenuseid ja serverita rakendusi.

Arvestades NodeJS-i populaarsust, oleme ka Flask vs. Node jaotises Flask vs. Node esitanud Flaski ja Node'i võrdluse. Django ja Flask'i hindamine järgmiste omaduste alusel aitab teil valida ühe üle teise.

Vaikimisi administraator

Mõlemad raamistikud pakuvad bootstrapped admin-rakendust. Django puhul on see sisseehitatud ja tuleb vaikimisi paigaldusega kaasa. Flaski puhul tuleb aga paigaldada Flask-Appbuilder, et saada admin-liides.

Vahepeal ärge unustage luua Django puhul superuser ja Flaski puhul admin, et saaksite brauseri abil administraatori backendisse sisse logida.

Andmebaasid ja ORMS

Django tarnitakse vaikimisi sisseehitatud ORM-iga, mis toetab otseselt suhtlemist selliste RDBMS-idega nagu Oracle, MySQL, PostgreSQL, SQLite jne. See ORM toetab ka migratsioonide genereerimist ja haldamist. Sisseehitatud valideerimistega andmebaasimudelite loomine on suhteliselt mugavam.

Flask ei sea samuti ette ühtegi kindlat meetodit ja seda on võimalik kasutada koos erinevate laiendustega, mis toetavad sarnaseid funktsioone, nagu on kirjeldatud Django puhul. Oleme ühes sarja õpetustes toonud näiteid Flask-SQLAlchemy, Flask-Migrate, Flask-MongoEngine kohta.

Vaated ja marsruudid

Mõlemal raamistikul on mehhanismid meetodipõhiste ja klassipõhiste vaadete deklareerimiseks. Django puhul on marsruute ja vaateid mainitud eraldi failides. Samuti tuleb alati päringu objekt selgesõnaliselt üle anda.

Teisest küljest saame Flaskis kasutada dekoraatorit, et mainida marsruute vastavate käitlejate jaoks. Taotluse objekt Flaskis on globaalne ja on lihtsalt kättesaadav ilma selgesõnalise edasiandmiseta. Oleme ühes meie õpiobjektis üksikasjalikult käsitlenud vaadete ja marsruutide kasutamise kontseptsioone.

Vormid ja mallid

Django vormid on raamistikku sisseehitatud ja ei vaja paigaldamist. Vormid on rakenduste jaoks üsna olulised ja Djangos saab vorme edastada mallide siltidele ja neid saab mallides esitada. Flaski puhul peame aga kasutama Flask-WTF-i.

Vormide loomiseks kasutasime ka Flask-Appbuilderit. Lisaks saab WTF-Alembiciga genereerida HTML-vormid andmebaasi mudelite põhjal.

Mõlemad raamistikud toetavad Jinja2 templating, ja mõlemad toetavad teenindavad staatilisi faile sisseehitatud funktsioonidega, et luua ressursside URL-id ja on üsna levinud muster kõigis raamistikes tänapäeval.

Kuigi muutujate edastamiseks ja mallide esitamiseks nende konkreetsetes vaate meetodites on erinevad viisid, on mõlemal raamistikul sama süntaks muutujate kasutamiseks mallides.

Paindlikkus

Django on oma suuruse ja keerukuse tõttu vähem paindlik kui Flask. Flask on kergesti laiendatav suure hulga laienduste abil, mida ta toetab. Seetõttu vajab Flaski seadistamine rohkem aega ja vaeva, sest me peame hindama rohkem laiendusi.

Arendajatele antud vabadus toob teatud mõttes kaasa aeglasema arengu ja tarnimise. Teisalt järgib Django juba kehtestatud konventsioone ja järgib arhetüüpe, mis nõuavad vähem kõrvalekaldeid projekti eesmärkidest ja eesmärkidest.

Õpikõver

Django ja Flask'i õppimiseks kulub peaaegu sama palju aega. Flask'il on väiksem API; seetõttu võivad inimesed selle kiiremini valmis saada, mis puudutab põhiraamistikku. Sama keeruliseks muutub see, kui tegemist on selle laienduste kasutamisega. See võib varsti muutuda tülikaks.

Kuid just seetõttu, et kõik ei ole pakitud ühte paketti, on Flask'i raamistiku puhul lihtsam harjutada probleemide lahusust.

Soovitame õppida mustreid, mitte järgitavat süntaksit. Nii Djangol kui ka Flaskil on suurepärane dokumentatsioon. Seda saab funktsioonide arendamisel hõlpsasti jälgida.

Projekti suurus ja kestus

Kui töötate suurema projekti kallal, kus on suuremad meeskonnad, on parem kasutada ära Django küpsust ja ulatuslikku kaasajate toetust. Kui teie projekt on väiksem ja vajab vähem arendajaid, on parem valida Flask.

Lisaks, kui teie projekt kestab kaua, siis on Django õige valik; vastasel juhul võite valida Flask.

Rakenduse tüüp

Varem peeti Djangot õigeks valikuks, kui oli vaja täisväärtuslikke ettevõtte veebirakendusi. Kuid tänapäeval on Flask sama küps ja võib samades tingimustes hästi toimida.

Kuid arendajad valivad Flaski pigem väikeste või staatiliste veebisaitide arendamiseks või RESTful API veebiteenuste kiireks pakkumiseks.

Arendaja värbamine

Kvalifitseeritud ressursside olemasolu kasutatava raamistiku konventsioonis tasub end ära. Võite oodata kiiremat arendamist, kiiremat testimist, kiiremat tarnimist ja kiiremat probleemide parandamist.

Flaski puhul on üsna lihtne leida uusi arendajaid. Django puhul on aga keeruline leida kvalifitseeritud ressursse. Django arendajaid ei ole palju valmis tööle võtma. Lisaks on Django raamistik üsna vana ja seetõttu on enamiku uute töötajate palkamine kallis võrreldes Flaski raamistiku oskustega.

Uued tehnikumi lõpetajad valivad ka kerged raamistikud nagu Flask, sest tööstuse suundumused on lahtiseotud mikroteenustega rakenduste loomise poole või tehnoloogia, mis toetab serverless rakendamise loomist. Javascript on laialdaselt kasutusel koos raamistike, mis on lihtsamini kasutatavad ja populaarsemad.

Avatud lähtekood

Nii Flask kui ka Django on avatud lähtekoodiga projektid. Django leiate aadressil //github.com/django/django/django ja Flask aadressil //github.com/pallets/flask. Neid projekte vaadates on Django toetajate arv üsna suurem kui Flaski toetajate arv.

Seetõttu võime oodata rohkem ja kiiremat tuge, kui meil on mõned probleemid ja päringud, mis vajavad lahendamist. Vastupidiselt tüüpilistele oletustele on Flask projekti kasutajate arv suurem kui Django oma.

Üks Flaskiga seotud puudutav asjaolu on see, et konkreetse ülesande jaoks ei pruugi olla stabiilset laiendust. Seetõttu jääb parima välja filtreerimise töö laienduse kasutajale.

Näiteks, me kasutasime Flask-Twitter-oembedderit, et töötada Twitteri API-ga eelmises õpetuses, kuid sellel laiendusel oli mõningaid probleeme, mille tõttu pidime Flask-Cache'i asemel kasutama Flask-Caching'i.

Me pidime isegi lisama kohandatud paigaldusavalduse Flask-twitter-oembedderi paigaldamiseks meie uuendatud Githubi repost, selle asemel, et seda projekti requrements.txt failis mainida.

Sage hooldus on tüüpiline väljakutse, millega avatud lähtekoodiga projekti puhul silmitsi seisate. Avatud lähtekoodiga projekti tugi ja haldamine on tavaliselt seotud tasuliste teenustega. Te võite olla sunnitud kaua ootama, et projekti toetajad mõne probleemi parandaksid.

Tulemuslikkus

Flask raamistik on kergem kui Django ja toimib paremini, kusjuures erinevused on tühised, eriti kui arvestada I/O operatsioone.

Vaadake allpool toodud võrdlusi. Taotluste arvu suurenemise korral jääb Flaski jõudlus peaaegu samaks. Django võtab aga rohkem aega mallide renderdamiseks pärast ORM-i abil andmete kättesaamist.

Python Flask Vs Django: Tabulatiivne võrdlus

# Omadused Django Kolb
1 Vaikimisi administraator Sisseehitatud Admin Backend Installige Flask-Appbuilder
2 Vaikimisi administraatori lubamine Veenduge, et settings.py failis eemaldate admini paigaldatud rakenduse kommentaarid.

...

# Taotluse määratlus

INSTALLED_APPS = [

"veebisait",

'django.contrib.admin',

# muu kood

]

...

Impordi AppBuilder ja SQLA flask_appbuilderist, initsialiseeri kõigepealt DB ja seejärel Appbuilder.

from flask import Flask

from flask_appbuilder import AppBuilder, SQLA

app=Flask(__name__)

db = SQLA(app)appbuilder=AppBuilder(app, db.session)

3 Loo administraatori kasutaja python manage.py createsuperuser flask fab create-admin
4 Andmebaasid ja ORMS Sisseehitatud ORM RDBMS-i jaoks

Kasutage Django-nonrel NoSQL backendide jaoks

Installige Flask-SQLAlchemy

NoSQL-spetsiifiline Flask laiendus nagu Flask-MongoEngine

5 Vaated ja marsruudid URLConf failis urls.py

from django.urls import path

alates .import views

urlpatterns = [

path('/path', views.handler_method),

# muud urlid ja käitlejad

]

Kasutage @app.route("/path") kaunistajat Views'ile, et kaardistada marsruut funktsiooniga.

@app.route("/path")

def handler_method():

# muu kood edasise loogikaga

6 Renderdamise mallid Vaadetes

from django.shortcuts import render

def example_view(request):

tempvar="value_for_template"

return render(

taotlus,

'demo.html',

{'tempvar':tempvar}

)

Vaadetes

from . import app

from flask import request

from flask import render_template

@app.route("/path")

def demo():

tempvar="value_for_template"

return render_template(

"demo.html",

temp_var=temp_var

)

7 Muutuv interpolatsioon mallides Templates/demo.html

{{ tempvar }}

Templates/demo.html

{{ tempvar }}

8 Paindlikkus Vähem paindlik Paindlikumad
9 Disainiotsused Vähem projekteerimisotsuseid koos arendajatega. Rohkem vabadust arendajatele.
10 Projekti kõrvalekaldumine Vähem kõrvalekaldumine projekti eesmärkidest. Rohkem kõrvalekaldeid tänu arendajatele antud vabadusele.
11 Koodibaasi suurus Suurem koodibaas Väiksem koodibaas
12 APIde arv Rohkem APIsid Vähem APIsid
13 Rakenduse tüüp Täielikud veebirakendused Väiksemad rakendused / mikroteenused
14 RESTful rakendused Django REST raamistik RESTful rakenduste jaoks. Kasutage järgmisi laiendusi RESTful rakenduste jaoks.

Flask-RESTful

Flask-RESTX

Ühendus

15 Tulemuslikkus Aeglane jõudlus, kui taotluste arv on suur. Järjepidev jõudlus kogu aeg.
16 Avatud lähtekoodiga panus Rohkem Forks, Watches ja Commits. Väiksem arv Forks, Watches ja Commits.
17 Arendajad Nõuab kogenud arendajaid ja neid ei ole lihtne värvata. Enamik arendajaid on vähem kogenud ja neid leidub piisaval arvul.

Flask Vs Node

Veebiarenduse korstnaga seoses selgub, et veebi jaoks arendamine nõuab erinevate tehnoloogiate ühendamist. Veebirakendus tuleb jagada frontendiks ja backendiks. Rakenduse frontend osa on kõige parem arendada tehnoloogiatega, mis töötavad brauseris, näiteks JavaScript, HTML ja CSS.

Üldiselt on backend arendatud serveripoolsetes keeltes, mis sobivad serveripoolseks kasutamiseks ja võivad vajaduse korral suhelda aluseks oleva operatsioonisüsteemi, ühendatud andmebaaside või võrguga.

JavaScriptil põhinev raamistik nimega NodeJS muutis aga eespool esitatud seisukohta ja võimaldas arendajatele järjepidevust ja ühtsust veebirakenduste esi- ja tagakülje arendamisel. Arendajad said arendada tagakülje jaoks JavaScriptiga.

Selles Flask vs Node osas võrdleme Flaski, mis on Pythoni programmeerimiskeelel põhinev raamistik, Node'iga, mis põhineb Chrome'i JavaScripti runtime'il erinevatel kriteeriumidel, nagu arhitektuur, kiirus, kogukonna toetus jne.

# Kriteeriumid Kolb Sõlme
1 Keele tööaeg Python Chrome'i V8 JavaScript mootor
2 Arhitektuur Mitteblokeeriv I/O nõuab mitteblokeerivate veebiserverite, näiteks gunicorn, kasutamist.

Mikroraamistiku (back end) kategooria.

Pakub loomupäraselt mitteblokeerivat I/O-d.

Fullstack kategooria

3 Pakettide haldur pip npm
4 Kiirus Aeglasem, sest eraldi Pythoni interpretaator on aeglasem. Kiirem tänu Just-In-Time kompilaatorile.
5 Avatud lähtekood Jah Jah
6 Ühenduse toetus Githubis

2.3 K Kellad

51,4 K Tähed

13,7 K Kahvlid

Githubis

2.9 K Kellad

71,9 K Tähed

17,6 K Kahvlid

7 Vigade kõrvaldamine Lihtsam tõrje Pythoni tõrjevahendiga ilma sõltuvusteta. Nõuab rohkem vaeva. Lihtsam arendus IDEga koos Bluebird / Promise Libraryga.
8 Hooldus Madal hoolduskoormus Kõrgemad hoolduskulud
9 Reaalajas rakendused Iseenesest ei sobi. Siiski võib see töötada koos socket.io'ga reaalajas kasutamise korral. Kasutage Flask-socketio laiendust. Sobib tänu sündmusepõhisele arhitektuurile ja voogesituse moodulitele. Iseenesest asünkroonne.
10 Raamatukogud Küpsem ja stabiilsem. Vähem küps ja stabiilne, kuid aktiivse arenduse ja parandatud versioonide raames.
11 Kood Kvaliteet See on loodud ainult tagumise osa jaoks. See on mõnikord ohus, sest uued esipoole arendajad lähevad üle backendile.
12 Arendustiimi koosseis Meeskonnad koosnevad tavaliselt back end arendajatest ja front end arendajatest. Kontseptsioonid on eraldi. Arendajad saavad vahetada rolle ja töötada nii esi- kui ka tagakülje jaoks.
13 Integratsioon olemasoleva süsteemi ja rakendustega Lihtsam integreerida teiste olemasolevate pärandrakendustega, kasutades Pythoni ökosüsteemi masinõppe ja suurandmete rakenduste jaoks. Üsna uus ja nõuab kohandatud või uute raamatukogude loomist teiste olemasolevate rakendustega integreerimiseks.

Korduma kippuvad küsimused

K #1) Mida ma peaksin kõigepealt õppima, kas Django või Flask?

Vastus: Kõigepealt on parem kasutada Flask'i. Kui olete omandanud pisut kogemusi veebiarenduses, võite võtta kasutusele Django. Django eeldab, et te juba teate, kuidas veebirakendused töötavad, ja ta hoolitseb suurema osa funktsionaalsuse eest ise.

K #2) Kas Flask või Django on parem?

Vastus: Nii Flask kui ka Django on suurepärased ja sobivad oma otstarbeks. Djangot kasutatakse silmapaistvamate ettevõtte mastaabis rakenduste loomiseks. Flaski kasutatakse staatiliste ja väiksemate rakenduste loomiseks. Flask sobib ka prototüüpimiseks. Flaski laienduste abil saame aga luua ka suuri rakendusi.

K #3) Millised ettevõtted kasutavad Flaski?

Vastus: Mõned ettevõtted, kes kasutavad Flaski, on Reddit, Mailgun, Netflix, Airbnb jne.

K #4) Millised saidid kasutavad Djangot?

Vastus: Mõned Djangot kasutavad näiteks Instagram, Spotify, YouTube, Dropbox, Bitbucket, Eventbrite jne.

Kokkuvõte

Me ei tohiks tegelikult pikalt ühe raamistiku külge kinnistuda. Me peaksime olema valmis õppima uusi tehnoloogiakomplekte ja võtma vastu sealse trendi stäkke. Mõned meist tahavad võrdlemisi out of the box, akut sisaldavaid lähenemisviise jäikade väljalaske tsüklitega, säilitades tihedamat tagasiühilduvust jne.

Kui arvate, et kuulute pigem sellesse gruppi, siis peate valima Django. Samas on uskumatu käia kaasas ka Flask raamistiku uute funktsioonide ja paindlikkusega. Kui soovite säilitada järjepidevust front- ja backend vahel, siis võite valida täieliku raamistiku, näiteks NodeJS.

Raamistiku valimine on pigem valik, mis sõltub kontekstist ja probleemidest, mida püüame lahendada. Raamistiku valimine on alati raske. Loodame, et oleme selles õpetuses esitanud olulised ülevaatepunktid ja see aitab teil ühe raamistiku lõplikul valikul. Soovitame siiski õppida mõlemad raamistikud.

Lihtsam on alustada Flaskiga ja seejärel liikuda edasi Django juurde, kui olete omandanud mõningaid kogemusi veebiarenduses. Kui mingil põhjusel on teie arendustegevuses vaja kasutada JavaScripti, siis võite jätkata NodeJSiga.

Keri üles