在Django中只显示最新的3个帖子?
我有一个用Django做的博客应用。我想在另一个页面上显示最新的3篇博客文章,但现在只能按日期显示所有的博客文章。
我该怎么才能显示最新的3篇文章呢?
这个过滤是应该在视图里做,还是在模板标签里做呢?
models.py
from django.db import models
from django.core.urlresolvers import reverse
# Create your models here.
class Post(models.Model):
title = models.CharField(max_length=200)
slug = models.SlugField(unique=True, max_length=255, null=True)
pub_date = models.DateTimeField()
excerpt = models.TextField(null=True)
text = models.TextField()
header_image = models.FileField(upload_to='blog/%Y/%m/%d', null=True, blank=True)
post_color = models.CharField(max_length=20, null=True)
tags = models.CharField(max_length=80, blank=True)
published = models.BooleanField(default=True)
def __unicode__(self):
return u'%s' % self.title
def get_absolute_url(self):
return reverse('blog.views.post', args=[self.slug])
views.py
from django.shortcuts import render, get_object_or_404
from blog.models import Post
def about(request):
# get the blog posts that are published
posts = Post.objects.filter(published=True).order_by('-pub_date')
# now return the rendered template
return render(request, 'blog/about.html', {'post': posts})
about.html
{% for post in post %}
<section class="post">
<h3><a class="post-title"
href="{{post.get_absolute_url}}">
{{ post.title }}
</a></h3>
<span class="post-meta">
{{ post.pub_date | date:"d F Y" }}
</span>
<p class="post-excerpt">
{{ post.excerpt }}
</p>
</section>
{% endfor %}
2 个回答
5
试着获取前3个元素的子数组。这个方法应该可以用。
posts = Post.objects.filter(published=True).order_by('-pub_date')[:3]
10
试试这个,
posts = Post.objects.filter(published=True).order_by('-pub_date')[0:3]