Dynamická data v šablonách
Máme různé části na svém místě: Post
model je definován v models.py
, post_list
máme v views.py
a máme přidanou šablonu. Ale jak skutečně přinutíme naše příspěvky objevit se v naší HTML šabloně? Protože to je to, co chceme: Vzít nějaký obsah (modely uložené v databázi) a zobrazit je hezky v naší šabloně, správně?
To je přesně to, co views mají dělat: spojovat modely a šablony. Do našeho post_list
view budeme potřebovat vzít modely, které chceme zobrazit a předat je šabloně. Takže v podstatě se ve view rozhodneme, co (model) bude zobrazeno v šabloně.
OK, tak jak toho dosáhneme?
Potřebujeme otevřít blog/views.py
. Prozatím post_list
view vypadá takhle:
from django.shortcuts import render
def post_list(request):
return render(request, 'blog/post_list.html', {})
Vzpomínáš si, jak jsme mluvily o zahrnování kódu napsaného v různých souborech? Teď je ten moment, kdy musíme zahrnout model, který jsme napsaly do models.py
. Přidáme tuto řádku from .models import Post
:
from django.shortcuts import render
from .models import Post
Tečka po from
znamená aktuální adresář nebo aktuální aplikace. Protože se views.py
a models.py
nachází ve stejném adresáři, můžeme jednoduše použít .
a jméno souboru (bez .py
). Potom importujeme název modelu (Post
).
Ale co dál? Abychom mohly vzít skutečné příspěvky z Post
, potřebujeme něco, čemu říkáme QuerySet
.
QuerySet
Už bys měla mít povědomí o tom, jak QuerySety fungují. To jsme probraly v kapitole Django ORM (QuerySets).
Takže teď nás zajímá seznam příspěvků, které jsou publikovány a setříděny podle published_date
, že? To jsme už udělaly v kapitole na QuerySety!
Post.objects.filter(published_date__lte=timezone.now()).order_by('published_date')
Teď tento kousek kódu vložíme do souboru blog/views.py
do funkce def post_list(request)
:
from django.shortcuts import render
from django.utils import timezone
from .models import Post
def post_list(request):
posts = Post.objects.filter(published_date__lte=timezone.now()).order_by('published_date')
return render(request, 'blog/post_list.html', {})
Vezmi, prosím, na vědomí, že jsme vytvořily proměnnou pro QuerySet: posts
. Považuj to za název našeho QuerySetu. Od teď k němu budeme referovat tímto názvem.
Kód také používá funkci timezone.now()
, takže potřebujeme přidat import pro timezone
.
Poslední chybějící část je předat posts
QuerySet do šablony (jak ho zobrazit si ukážeme v další kapitole).
Ve funkci render
už máme parametr request
(všechno, co přijmeme od uživatele přes internet) a šablonu 'blog/post_list.html'
. Poslední parametr, který vypadá takhle: {}
, je místo, kam můžeme přidat nějaké věci, u kterých chceme, aby je šablona mohla používat. Potřebujeme je pojmenovat (teď zůstaneme u 'posts'
:)). Mělo by to vypadat takhle: {'posts': posts}
. Všimni si, prosím, že část před :
je string: musíš ho obalit uvozovkami ''
.
A nakonec by náš blog/views.py
soubor měl vypadat takhle:
from django.shortcuts import render
from django.utils import timezone
from .models import Post
def post_list(request):
posts = Post.objects.filter(published_date__lte=timezone.now()).order_by('published_date')
return render(request, 'blog/post_list.html', {'posts': posts})
A je to! Čas jít zpět do šablony a zobrazit tento QuerySet!
Pokud si chceš přečíst něco víc o QuerySetech v Django, měla by ses podívat sem: https://docs.djangoproject.com/en/1.8/ref/models/querysets/