【发布时间】:2018-04-10 13:28:49
【问题描述】:
我的问题出在 Paginator get_page() 方法上。这是我的视图代码:
@login_required
def photo_index_default_album(request):
album = Album.get_default_album(request.user)
photo_list = album.photo_set.all()
paginator = Paginator(photo_list, 2) # Show 2 photo per page
page = request.GET.get('sayfa')
photos = paginator.get_page(page)
context = {
'title': album.name,
'photo': photos,
}
return render(request, 'photo/index.html', context)
paginator.get_page(page) 仅适用于 1. 页。在第二页之后,它返回一个页面,其中包含一个带有空 QuerySet 的 object_list。
顺便说一句,可能这是一个基础知识。我只是想知道,这两个分配有什么区别:
选项 1:
photo_list = Photo.objects.all()
photo_list.filter(Q(album=album.id))
和
选项2:
photo_list = Photo.objects.filter(album=album.id)
更新: 好的,我了解 2 个选项之间的区别。但是我的问题还在继续。我根据您的有用答案更新了上面的查询代码。
问题:此分页仅适用于 1. 分页。如果页面值的 'sayfa' 变量变得不同于 1,则它不起作用。在这种情况下,paginator.get_page() 返回一个页面,该页面有一个带有空 QuerySet 的 object_list。检查 photo_list.count() 页面,它们在每次调用中都是正确的。模板中的分页器变量也适用于第一页和最后一页。但我没有显示空返回的图像原因。为什么 paginator.get_page(page) 返回一个带有空 QuerySet 的 object_list 而分页不同于 1?顺便说一句,我使用 MongoDB 作为数据库后端。
奇怪的事情:如果我指定 photo_list = Photo.objects.all(),我的模板按预期工作。但我只想显示特定相册的照片。 最后的更新说明:由于图片太多我没有注意到问题,它也是错误的。
最终更新:(解决方案) 查询结果错误的原因是关于 Djongo 包的 LIMIT-OFFSET 查询的错误。我打开了一个问题,https://github.com/nesdis/djongo/issues/106。
我的模型:
class Photo(models.Model):
image = models.ImageField()
album = models.ManyToManyField(Album)
class Album(models.Model):
name = models.CharField(max_length=150)
user = models.ForeignKey('accounts.MyUser', verbose_name='Album Owner', on_delete=models.CASCADE)
我的模板:很抱歉给您带来不便,有点长..
{% extends 'base.html' %}
{% block title %}
{{ block.super }} - {{ title }}
{% endblock %}
{% block body %}
<div class="container">
{% for pht in photo %}
<div class="row justify-content-center" style="margin-bottom: 30px">
<div class="col-md-6">
<div class="card">
{% if pht.image %}
<img class="card-img-top img-fluid" src="{{ pht.image.url }}" alt="Card image cap">
{% endif %}
<div class="card-body">
<h5 class="card-title">{{ title }}
<small style="color: #4e555b"> {{ pht.upload_date|timesince }} before</small>
</h5>
{% if request.user.is_authenticated %}
<a href="{{ pht.get_delete_url }}" class="btn btn-danger">Delete</a>
{% endif %}
</div>
</div>
</div>
</div>
{% endfor %}
<div class="row justify-content-center" style="margin-bottom: 30px">
<div class="col-md-6">
<div class="pagination">
<span class="step-links">
{% if photo.has_previous %}
<a href="?sayfa=1{% if request.GET.q %}&q={{ request.GET.q }}{% endif %}">« first</a>
<a href="?sayfa={{ photo.previous_page_number }}{% if request.GET.q %}&q={{ request.GET.q }}{% endif %}">previous</a>
{% endif %}
<span class="current">
Page {{ photo.number }} of {{ photo.paginator.num_pages }}.
</span>
{% if photo.has_next %}
<a href="?sayfa={{ photo.next_page_number }}{% if request.GET.q %}&q={{ request.GET.q }}{% endif %}">next</a>
<a href="?sayfa={{ photo.paginator.num_pages }}{% if request.GET.q %}&q={{ request.GET.q }}{% endif %}">last »</a>
{% endif %}
</span>
</div>
</div>
</div>
</div>
{% endblock %}
【问题讨论】:
标签: python django pagination