Django中提供了一个类Paginator专门用来管理和处理分页数据,所以我们在使用之前先导入好相应的类,,另外这里我们也导入了待会会用到的处理异常的两个类 EmptyPage和PageNotAnInteger:
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
接着编写好视图函数test:
def test(request): course_list=CourseVideo.objects.all() #生成pagintor对象,定义每页显示10条记录 paginator=Paginator(course_list,10) #获取当前的页码数,默认为1 page=request.GET.get("page",1) #把当前的页码数转换为整数类型 currentPage=int(page) try: video_list=paginator.page(page)#获取当前页码的记录 except PageNotAnInteger: video_list=paginator.page(1)#如果用户输入的页码不是整数时,显示第1页的内容 except EmptyPage: video_list=paginator.page(paginator.num_pages)#如果用户输入的页码不是整数时,显示第1页的内容 return render(request, "test.html", locals())
接下来我们完成前端页面的逻辑,这里定义的文件为test.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>这里的标题</title> </head> <body> <div class="manageContent"> {#数据显示div--start#} {% for video in video_list%} <div id="{{ video.vidoeContentId }}" class="content9"> <div class="videomsg"> <img src="/static/images/favicon.ico" alt="" /> <span >{{ video.name }}</span> </div> <span class="courseTime" >{{ video.number }}</span> <span class="sourse" >{{ video.source }}</span> <span class="status" >{{ video.status }}</span> <div class="operate"> <span style="cursor:pointer;" onclick="ShowUpDiv('upfileDiv','fade1','{{ video.id }}','{{ video.name }}')">上传</span> <span style="cursor:pointer;" onclick="ShowEditDiv('editDiv','editfade','{{ video.name }}','{{ video.number }}','{{ video.source }}','{{ video.status }}','{{ video.id }}')" >修改</span> <span style="cursor:pointer;" onclick="Showdetail('{{ video.id }}')" >详情</span> </div> <div id="{{ video.id }}" style="display: none ;overflow:scroll;overflow-x:hidden"> </div> </div> {% endfor %} {#数据显示div--end#} {#显示分页导航栏--start#} <div class="kkk"> <ul class="pagination" id="pager" > {#上一页按钮开始#} {# 如果当前页有上一页#} {% if video_list.has_previous %} {# 当前页的上一页按钮正常使用#} <li class="previous"><a href="/backstage/test/?page={{ video_list.previous_page_number }}" >上一页</a></li> {% else %} {# 当前页的不存在上一页时,上一页的按钮不可用#} <li class="previous disabled"><a href="#" >上一页</a></li> {% endif %} {#上一页按钮结束#} {# 页码开始#} {% for num in paginator.page_range %} {% if num == currentPage %} <li class="liactive"><a class="selected" href="/backstage/test/?page={{ num }}" >{{ num }}</a></li> {% else %} <li class="itemli"><a href="/backstage/test/?page={{ num }}" >{{ num }}</a></li> {% endif %} {% endfor %} {#页码结束#} {# 下一页按钮开始#} {% if video_list.has_next %} <li class="next"><a href="/backstage/test/?page={{ video_list.next_page_number }}" >下一页</a></li> {% else %} <li class="next disabled"><a href="#" >下一页</a></li> {% endif %} {# 下一页按钮结束#} </ul> </div> {#显示分页导航栏--end#} </div> </body> </html>
至此,分页显示的逻辑完成,更多关于Paginator的语法实例如下:
from django.core.paginator import Paginator objects = ['john','paul','george','ringo','lucy','meiry','checy','wind','flow','rain']<br> p = Paginator(objects,3) # 3条数据为一页,实例化分页对象 print p.count # 10 对象总共10个元素 print p.num_pages # 4 对象可分4页 print p.page_range # xrange(1, 5) 对象页的可迭代范围 page1 = p.page(1) # 取对象的第一分页对象 print page1.object_list # 第一分页对象的元素列表['john', 'paul', 'george'] print page1.number # 第一分页对象的当前页值 1 page2 = p.page(2) # 取对象的第二分页对象 print page2.object_list # 第二分页对象的元素列表 ['ringo', 'lucy', 'meiry'] print page2.number # 第二分页对象的当前页码值 2 print page1.has_previous() # 第一分页对象是否有前一页 False print page1.has_other_pages() # 第一分页对象是否有其它页 True print page2.has_previous() # 第二分页对象是否有前一页 True print page2.has_next() # 第二分页对象是否有下一页 True print page2.next_page_number() # 第二分页对象下一页码的值 3 print page2.previous_page_number() # 第二分页对象的上一页码值 1 print page2.start_index() # 第二分页对象的元素开始索引 4 print page2.end_index() # 第2分页对象的元素结束索引 6
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍简单实现JSP分页显示效果,包括了简单实现JSP分页显示效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JSP分页显示效果的具体代码,供大家参考,具体内容如下 1、mysql的limit关键字 (DAO) tablename 就是要分页显示的那张表的名称; startPoint 就是起始的位置 -1; numberPerPage 就是一页显示的条数。 例如: sel
本文向大家介绍JSP实现的简单分页显示效果代码,包括了JSP实现的简单分页显示效果代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JSP实现的简单分页显示效果代码。分享给大家供大家参考,具体如下: 希望本文所述对大家JSP程序设计有所帮助。
本文向大家介绍Django rest framework实现分页的示例,包括了Django rest framework实现分页的示例的使用技巧和注意事项,需要的朋友参考一下 第一种分页PageNumberPagination 基本使用 (1)urls.py (2)api/utils/serializers/pager.py (3)views.py (4)settings配置 自定义分页类 第二种
本文向大家介绍基于Jquery+Ajax+Json实现分页显示附效果图,包括了基于Jquery+Ajax+Json实现分页显示附效果图的使用技巧和注意事项,需要的朋友参考一下 1.后台action产生json数据。 2.struts.xml相关配置 3.js获取json数据分页显示
本文向大家介绍thinkphp实现分页显示功能,包括了thinkphp实现分页显示功能的使用技巧和注意事项,需要的朋友参考一下 先上效果图,突然发现和B站上一样 IndexController.class.php代码如下 index.html代码如下 css代码如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍Django框架实现的分页demo示例,包括了Django框架实现的分页demo示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Django框架实现的分页。分享给大家供大家参考,具体如下: 首先初始化model,建表 然后用pycharm的数据库模块可视化插入 分页思路 url传递参数http://127.0.0.1:8000/books/?page=5比如这样传递的参数