Django 分页器的使用

Django作为Python Web开发框架的一哥,提供了企业级网站开发所需要的几乎所有功能,其中就包括自带分页功能。利用Django自带的Paginator类,我们可以很轻松地实现分页。Django 2.0和1.X最大的不同在于新增了get_page()方法。我们现在来具体看看有什么不同。

Django 1.X 和Django 2.0下实现分页

利用Django实现分类非常简单,我们只需要修改views.py和模板template。Django 1.X下实现分页代码如下:

# app/views.py - 基于函数的视图

from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

from .models import Article

from django.shortcuts import render

def article_list(request):

    article_list = Article.objects.all()

    paginator = Paginator(article_list, 10)  # 实例化一个分页对象, 每页显示10个

    page = request.GET.get('page')  # 从URL通过get页码,如?page=3

    try:

        articles = paginator.page(page)  # 获取某页对应的记录

    except PageNotAnInteger:  # 如果页码不是个整数

        articles = paginator.page(1)  # 提取第一页的记录

    except EmptyPage:  # 如果页码太大,没有相应的记录

        articles = paginator.page(paginator.num_pages)  # 提取最后一页的记录

    return render(request, 'article_list.html', {'articles': articles})

你注意到没有?上段代码的try和2个except非常重要,但是看上去有些冗余。Django 2.0下新增了get_page()方法,可以将代码大大简化(如下图所示)。它所实现的功能与上面是一样的。当用户提交的页码不是整数时,提取第一页记录。当用户输入的页码太大时,只提取最后一页记录。

from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

from .models import Article

from django.shortcuts import render

def article_list(request):

    article_list = Article.objects.all()

    paginator = Paginator(article_list, 10)  # 实例化一个分页对象, 每页显示10个

    page = request.GET.get('page')  # 从URL通过get页码,如?page=3

   articles = paginator.get_page(page)  # 获取某页对应的记录, 如果

    return render(request, 'article_list.html', {'articles': articles})

Django 1.X和2.0下的模板是一样的。这里提供两种显示方案。

模板一: 上一页, Page 1 of 3, 下一页

#app/templates/app/article_list.html

{% for article in articles %}

    {{ article.title }}  

{% endfor %}

<div class="pagination">

    <span class="step-links">

        {% if articles.has_previous %}

            <a href="?page=1">« first</a>

            <a href="?page={{ articles.previous_page_number }}">previous</a>

        {% endif %}

        <span class="current">

            Page {{ articles.number }} of {{ articles.paginator.num_pages }}.

        </span>

        {% if articles.has_next %}

            <a href="?page={{ articles.next_page_number }}">next</a>

            <a href="?page={{ articles.paginator.num_pages }}">last »</a>

        {% endif %}

    </span>

</div>

模板二: Page 1, 2, 3, 4, 5, 6, 7, 8, ... (推荐)

#app/templates/app/article_list.html

# Pagination style 2

{% for article in articles %}

    {{ article.title }}

{% endfor %}

<div class="pagination">

<nav>

    <ul class="pagination">

        {% if articles.has_previous %}

        <li class="">

        <a href="?page={{ articles.previous_page_number }}" aria-label="Previous">

        <span aria_hidden="true">«</span></a>

        </li>

        {% endif %}

        {% for page_num in articles.paginator.page_range %}

            {% if page_num == articles.number %}

         <li class="active"><a href="?page={{ page_num }}">{{page_num}}</a> </li>

            {% else %}

         <li class=""><a href="?page={{ page_num }}">{{page_num}}</a> </li>

            {% endif %}

        {% endfor %}

        {% if articles.has_next %}

         <li class="">

              <a href="?page={{ articles.next_page_number }}" aria-label="Next">

                  <span aria_hidden="true">»</span></a>

        </li>

      {% endif %}

    </ul>

</nav>

</div>

Django如何在基于类的视图里使用分页?

上述案例里我们使用了函数试图,很容易定义page对象, 并传递给模板,例如articles。但是如果我们希望使用基于类的视图,我们该如何实现分页呢?其实操作非常简单。我们只需在视图中加入paginate_by = number即可。

from. models import Article

from django.views.generic import ListView

class ArticleListView(ListView):

    model = Article  # 等于 queryset = models.Article.objects.all()

    template_name = 'app/article_list.html'  # 可选的

    context_object_name = "article_list"    # 默认context名字

    paginate_by = 10  # 每页10项

此时模板article_list.html也需要做出相应调整,如下图所示。Django会先对是否分页is_paginated做个判断,如果有,就会自动生成个page_obj分页对象传递到模板。

{% if article_list %}

    {% for article in article_list %}

    {{ article.title }}

    {% endfor %}

    {% if is_paginated %}

    <ul class="pagination">

    {% if page_obj.has_previous %}

    <li>

        <span><a href="?page={{ page_obj.previous_page_number }}">Previous</a></span>

    </li>

    {% endif %}

    <li class="">

        <span>Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}.</span>

    </li>

    {% if page_obj.has_next %}

          <li>

        <span><a href="?page={{ page_obj.next_page_number }}">Next</a></span>

    </li>

    {% endif %}

    </ul>

{% else %}

    <h3>Articles</h3>

    <p>No article yet</p>

{% endif %}

Django 分页器的使用的更多相关文章

  1. Django分页器的设置

    Django分页器的设置 有时候在页面中数据有多条时很显然需要进行分页显示,那么在python中django可以这样设置一个分页处理 怎么样去设置呢? 我们要用到  Django  中的  Pagin ...

  2. Django分页器和自定义分页器

    一.自定义分页器 import copy class Pagination(): def __init__(self,request,current_page,all_data_num,each_pa ...

  3. django -----分页器组件

    分页器组件 本文目录 1 Django的分页器(paginator)简介 2 应用View层 3 模版层 index.html 4 扩展 回到目录 1 Django的分页器(paginator)简介 ...

  4. Django 2.0 学习(19):Django 分页器

    Django 分页器 要使用Django实现分页功能,必须从Django中导入Paginator模块(painator - 分页器) views.py from django.shortcuts im ...

  5. Django - Cookie、Session、自定义分页和Django分页器

    2. 今日内容 https://www.cnblogs.com/liwenzhou/p/8343243.html 1. Cookie和Session 1. Cookie 服务端: 1. 生成字符串 2 ...

  6. Django 分页器 缓存 信号 序列化

    阅读目录 分页器 缓存 信号 序列化 Django分页器  (paginator) 导入 from django.core.paginator import Paginator, EmptyPage, ...

  7. django分页器

    网站页面的分页效果可以通过分页器实现 分页器的使用 urls.py from django.contrib import admin from django.urls import path from ...

  8. 7.Django|分页器

    Django的分页器paginator 文件为pageDemo models.py from django.db import models # Create your models here. cl ...

  9. 7 Django分页器文章分页

    1.复习 2.这节课要解决的问题? 3.分页的原理 4.准备工作 (1)创建Django项目 C:\Users\Administrator\Desktop\root3>django-admin ...

随机推荐

  1. Chrome---谷歌浏览器修改用户缓存文件夹 如何设置缓存路径

    1.首先我们在电脑上打开chrome浏览器,然后地址栏输入chrome://Version,然后按下回车键,找到个人资料路径一项. 2.接下来我们选中个人资料路径后面所有的信息,右键点击信息后选择“复 ...

  2. Django--ORM 多表查询

    一 . 建立外键 一对一建立外键 外键名称 = models.OneToOneField(to='要连接的类名', to_field='字段') 一对多建立外键 外键名称 = models.Forei ...

  3. asyncio并发编程

    一. 事件循环 1.注: 实现搭配:事件循环+回调(驱动生成器[协程])+epoll(IO多路复用),asyncio是Python用于解决异步编程的一整套解决方案: 基于asynico:tornado ...

  4. 转载 -- CSS3 中关于 select 下拉列表的样式

    截图效果:

  5. How to mount HFS EFI on macOS

    mount_hfs /dev/disk0s1 /volumes/efi

  6. 跳转语句之continue

    js里面有两个跳转语句,一个是continue,一个是break.由于这两个跳转语句都是用于循环当中,因此他们也就只能用于while.for.do…while语句中,当然了,break多加一个swit ...

  7. cuda编程视频资料

    胡文美教授 http://www.gpuworld.cn/article/show/463.html

  8. Go For It ,一个灵活的待办事项列表程序

    导读 Go For It,是我们开源工具系列中的第十个工具,它将使你在 2019 年更高效,它在 Todo.txt 系统的基础上构建,以帮助你完成更多工作. 每年年初似乎都有疯狂的冲动想提高工作效率. ...

  9. vs + babelua + cocos2d-x

    https://blog.csdn.net/dugaoda/article/details/60467037 https://blog.csdn.net/taotanty/article/detail ...

  10. kubernetes 编排详解 挂载

    ##kube挂载本地磁盘apiVersion: v1 kind: Pod metadata: name: redis spec: containers: - name: redis image: re ...