python+Django完成分页功能

#实现Django分页功能
平时在一些网站上能看到下面的分页功能,内容过多只能在每页显示20条左右,就像下面这个图片一样,
python+Django完成分页功能_第1张图片

下面是我练习的代码仅供参考,没步骤都有详细的介绍!
首先导入的是Paginator类,
Paginator 类的作用是将我们需要分页的数据分割成若干份。当我们实现化一个 Paginator 类的实例时,需要给 Paginator 传入两个参数。第一个参数是数据源,可以是一个列表、元组、以及查询结果集 QuerySet。第二个参数需要传入一个整数,表示每页显示数据条数。

  def index(request):
      object_list = Post.objects.all()
     # 获取所有的文章
      paginator = Paginator(object_list, 3)
      #每页的文章数目为3个
      page = request.GET.get('page')
      #得到第几页
    try:
        posts = paginator.page(page)
      #正常显示第几页
    except PageNotAnInteger:
       #数据烂输的话显示第1页
        posts = paginator.page(1)
    except EmptyPage:
      #大于总文章的话显示的话显示最后一页
        posts = paginator.page(paginator.num_pages)
    return render(request, 'index.html', {'page': page, 'posts': posts})
      #将数据传入那个网页
{% csrf_token %} #防止跨站请求 {{ form.as_p }}

使用django自带的表单实现功能,

直接复制复制粘贴就好

{% if page.has_previous %}
    上一页
{% endif %}

第 {{ page.number }} 页 ,共 {{ page.paginator.num_pages }}页

    {% for pg in page.paginator.page_range %}
        {{ pg }}
    {% endfor %}

{% if page.has_next %}
    下一页
{% endif %}

大家可以参考下我的思路,如果有错误大家帮我指出来。谢谢

你可能感兴趣的:(python)