Django实现分页显示效果
作者:LinBigCat 发布时间:2021-12-04 14:01:37
标签:django,分页显示
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
来源:https://blog.csdn.net/qq_34493908/article/details/83536907


猜你喜欢
- 本文介绍在Anaconda环境下,安装Python中栅格、矢量等地理数据处理库GDAL的方法。需要注意的是,本文介绍基于conda inst
- mark标记在实际工作中,我们要写的自动化用例会比较多,也不会都放在一个py文件中,如果有几十个py文件,上百个方法,而我们只想运行当中部分
- map()函数map() 会根据提供的函数对指定序列做映射,是内置函数第一个参数 function 以参数序列中的每一个元素调用 funct
- 背景: 由于工作需要,现在有这么一个需求,要合并大量的word文档,而且要在不同的目录
- 本文实例为大家分享了python3.4函数操作mysql数据库的具体代码,供大家参考,具体内容如下#!/usr/bin/env python
- 前端技术层(图片有点偏激,仅供参考)Javascript和DOM关系很暧昧,弄不明白!CSS和HTML
- 记忆力差的孩子得勤做笔记!刚接触python,最近又需要画一个三维图,然后就找了一大堆资料,看的人头昏脑胀的,今天终于解决了!好了,废话不多
- python的新式类是2.2版本引进来的,我们可以将之前的类叫做经典类或者旧式类。为什么要在2.2中引进new style class呢?官
- 已经记不得是在哪个网站上看到的了,一般情况下对于验证码的校验,大家很容易写成下面这样: <% If Request.Form(&quo
- 本文实例讲述了C语言实现访问及查询MySQL数据库的方法。分享给大家供大家参考,具体如下:1、添加头文件路径(MySQL安装路径中的incl
- 以select为例,如果select写在循环里,触发change事件时可能不只需要传递被选中项的值,还要传递index过去,来改变同一循环中
- 说明可以调取k8s API 接口的工具有很多,这里我就介绍下client-gogitlab上client-go项目地址: https://g
- 一看,C盘只有不到2M可用空间,一查原因,sqlserver安装路径下的log目录文件占了好大,5G多, 于是上网搜了下,解决了: 把与sq
- 在机器上首次安装MySQL,操作系统是win7mysql 的安装文件是 zip 格式的,版本是5.7.17解压之后,安装步骤是1、首先找个文
- 多条ROC曲线绘制函数def multi_models_roc(names, sampling_methods, colors, X_tes
- 1. 背景最近在爬取某个站点时,发现在POST数据时,使用的数据格式是request payload,有别于之前常见的 POST数据格式(F
- 在项目中,经常会碰到往数据库中导入大量数据,以便利用sql进行数据分析。在导入数据的过程中会碰到一些需要解决的问题,这里结合导入一个大约4G
- 用uniapp开发APP时,为了开发方便,经常是H5开发好,然后再弄APP的兼容性问题。所以可能会涉及到跨域,此时也可以让后端同学帮忙,但是
- 1、在模块中,我们需要判断__name__是否被赋值为“__main__”。python fibo.py <arguments>
- 变量方法举例备注用变量存储值name = "xxx"print("name ", name )小写字