首先,感谢您阅读我的问题:) 我目前正在开发一个小型的Blog平台,我希望为我的所有Post元素实现分页。 因此我修改了我的view.py和实际的.html模板。 现在的问题是,每次我访问post_list.html页面时,我点击下一步没有任何事情发生..这里有什么问题:
post_list.html
{% extends 'quickblog/base.html' %}
{% block content %}
{% for post in posts %}
<br>
<div class="post">
<h1><u><a href="{% url 'post_detail' pk=post.pk %}">{{ post.title }}</a></u></h1>
<p>{{ post.text|linebreaksbr }}</p>
<div class="date">
<a>published by: {{ post.author }}</a><br>
<a>published at: {{ post.published_date }}</a><br>
<a>tags: {{ post.tag }}</a>
</div>
</div>
{% endfor %}
<div class="pagination">
<span class="step-left">
{% if posts.has_previous %}
<a href="?page=1">« first</a>
<a href="?page={{ posts.previous_page_number }}">previous</a>
{% endif %}
<span class="current">
Page {{ posts.number }} of {{ posts.paginator.num_pages }}.
</span>
{% if posts.has_next %}
<a href="?page={{ posts.next_page_number }}">Next</a>
<a href="?page={{ posts.paginator.num_pages }}">Last »</a>
{% endif %}
</span>
</div>
{% endblock %}
views.py
def post_list(request):
list_posts = Post.objects.get_queryset().order_by('created_date')
paginator = Paginator(list_posts, 15) # Show 15 Posts per page
page = request.GET.get('posts')
posts = paginator.get_page(page)
return render(request, 'quickblog/post_list.html', {'posts': posts})
答案 0 :(得分:2)
在模板中,您使用page
作为查询参数。所以你也应该在视图中使用它。
模板:
<a href="?page={{ posts.next_page_number }}">Next</a>
视图:
page = request.GET.get('page') # not .get('posts')
答案 1 :(得分:0)