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. 动态SQL1

    If标签 动态SQL可以说是MyBatis最强大之处了,这块的应用主要有四个方面if,choose,trim和foreach,接下来先说说if. 顾名思义,if是用来判断条件的,现在假设我们有个需求, ...

  2. 结巴(jieba)分词

    一.介绍: jieba: “结巴”中文分词:做最好的 Python 中文分词组件 “Jieba” (Chinese for “to stutter”) Chinese text segmentatio ...

  3. Java线程的5种状态及切换(透彻讲解)-京东面试

    一.Thread的几个重要方法: 我们先了解一下Thread的几个重要方法. a.start()方法,开始执行该线程:b.stop()方法,强制结束该线程执行:c.join方法,等待该线程结束.d.s ...

  4. 简单比较init-method,afterPropertiesSet和BeanPostProcessor

    一.简单介绍 1.init-method方法,初始化bean的时候执行,可以针对某个具体的bean进行配置.init-method需要在applicationContext.xml配置文档中bean的 ...

  5. python数据结构与算法第六天【栈与队列】

    1.栈和队列的原理 栈:后进先出(LIFO),可以使用顺序表和链表实现 队列:先进先出(FIFO),可以使用顺序表和链表实现 2.栈的实现(使用顺序表实现) #!/usr/bin/env python ...

  6. vs code的快捷方式

    https://blog.csdn.net/qq_41308027/article/details/83178526

  7. vue 子组件修改父组件传来的props值,报错

    vue不推荐直接在子组件中修改父组件传来的props的值,会报错 [Vue warn]: Avoid mutating a prop directly since the value will be ...

  8. sql left join多表

    表A---------------------------------关联第一张表B-----------------------关联第二张表c select * fomr 表名A left join ...

  9. Lodop打印维护PRINT_SETUP本地缓存ini文件

    针对千差万别的客户端,Lodop提供了打印维护(PRINT_SETUP),可以针对某个客户端微调,调整结果保存在客户端本地,不会影响其他访问网站的用户的使用. 打印维护使用方法:1.PRINT_INI ...

  10. JavaScript学习笔记之数组(二)

    JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...