Django分页类的封装

Django ORM 

封装

之前有提到(Django分页的实现)会多次用到分页,将分页功能封装起来能极大提高效率。

其实不是很难,就是将之前实现的代码全都放到类中,将需要用到的参数,比如,page_num, total_count, url_prefix, per_page, max_page,以参数的形式传到类中进行初始化,而后的实现代码即可用 self.变量名 的形式使用自己分页类内部的变量。

Page 类

class myPage():
def __init__(self, page_num, total_count, url_prefix, per_page=10, max_page=11):
""" :param page_num: 当前页码数
:param total_count: 数据总数
:param url_prefix: a标签href的前缀
:param per_page: 每页显示多少条数据
:param max_page: 页面上最多显示几个页码
"""
self.url_prefix = url_prefix
self.max_page = max_page
self.per_page = per_page total_page, m = divmod(total_count, per_page)
if m > 0:
total_page += 1 self.total_page = total_page try:
page_num = int(page_num)
# 如果输入页码数过大,默认跳到最后一页
if page_num > total_page:
page_num = total_page
except Exception as e:
page_num = 1 self.page_num = page_num self.data_start = (page_num - 1) * 10
self.data_end = page_num * 10 # 1. 先实现一半一半
max_page = 11
# 10. 如果数据量少,页数也少
if total_page < max_page:
self.max_page = total_page
half_max_page = max_page // 2
page_start = page_num - half_max_page
page_end = page_num + half_max_page # 2. 特殊情况一:页码前面出现负值
if page_start < 1:
page_start = 1
page_end = self.max_page # 3. 特殊情况二:页码后面出现空白页
if page_end >= total_page:
page_start = total_page - self.max_page + 1
page_end = total_page self.page_start = page_start
self.page_end = page_end @property
def start(self):
return self.data_start @property
def end(self):
return self.data_end def page_html(self):
page_html_list = [] # 9. 解决在首页处点前一页
if self.page_num == 1:
page_html_list.append(
'<li class="disabled"><a href="#"><span aria-hidden="true">&laquo;</span></a></li>')
else:
page_html_list.append(
'<li><a href="{0}?pages={1}"><span aria-hidden="true">&laquo;</span></a></li>'.format(self.url_prefix,
self.page_num - 1)) # 4. 加上首页
page_html_list.append('<li><a href="{}?pages=1">首页</a></li>'.format(self.url_prefix)) for i in range(self.page_start, self.page_end + 1):
# 11. 对当前页加上活动active样式类
if i == self.page_num:
temp = '<li class="active"><a href="{0}?pages={1}">{1}</a></li>'.format(self.url_prefix, i)
else:
temp = '<li><a href="{0}?pages={1}">{1}</a></li>'.format(self.url_prefix, i)
page_html_list.append(temp) # 5. 加上尾页
page_html_list.append('<li><a href="{0}?pages={1}">尾页</a></li>'.format(self.url_prefix, self.total_page)) # 8. 解决最后一页时点后一页
if self.page_num == self.total_page:
page_html_list.append(
'<li class="disabled"><a href="#" aria-label="Next"><span aria-hidden="true">&raquo;</span></a></li>')
else:
page_html_list.append(
'<li><a href="{0}?pages={1}" aria-label="Next"><span aria-hidden="true">&raquo;</span></a></li>'.format(
self.url_prefix,
self.page_num + 1)) # 转成字符串
page_html = "".join(page_html_list)
return page_html

前端模板代码

前端模板代码没有什么改变

<div class="container">
<table class="table table-bordered">
<thead>
<tr>
<th>序号</th>
<th>id</th>
<th>部门名称</th>
</tr>
</thead>
<tbody>
{% for dept in depts %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ dept.id }}</td>
<td>{{ dept.name }}</td>
</tr>
{% endfor %} </tbody>
</table> <nav aria-label="Page navigation">
<ul class="pagination"> {{ page_html|safe }} </ul>
</nav>
</div>

views 中的代码

只需要实例化分页类就能实现分页操作,与之前的方法相比,代码量减少了不少。

def depts(request):
# 从相应模块中导入分页类
from utils.myPage import myPage all_depts = models.Dept2.objects.all()
page_num = request.GET.get("pages")
total_num = models.Dept2.objects.all().count() # 实例化分页类
page_obj = myPage(page_num, total_num, '/depts/', per_page=10, max_page=11)
# 通过实例的变量从数据库中取出需要展示的数据
ret = models.Dept2.objects.all()[page_obj.start:page_obj.end]
# 由实例调用函数生成需要的HTML代码
dept_page_html = page_obj.page_html()
return render(request, "depts.html", {"depts": ret, "page_html": dept_page_html})

效果图

GitHub地址:https://github.com/protea-ban/oldboy/tree/master/s9day71/ormday71

Django分页类的封装的更多相关文章

  1. 自定义MVC框架之工具类-分页类的封装

    以前写过一个MVC框架,封装的有点low,经过一段时间的沉淀,打算重新改造下,之前这篇文章封装过一个验证码类. 这次重新改造MVC有几个很大的收获 >全部代码都是用Ubuntu+Vim编写,以前 ...

  2. php 之 分页查询的使用方法及其类的封装

    一.分页的使用: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  3. Django 自定义分页类

    分页类代码: class Page(object): ''' 自定义分页类 可以实现Django ORM数据的的分页展示 输出HTML代码: 使用说明: from utils import mypag ...

  4. Django 实现的分页类

    后台实现的一个分页类: from django.utils.safestring import mark_safe class Page: def __init__(self, current_pag ...

  5. php四个常用类封装 :MySQL类、 分页类、缩略图类、上传类;;分页例子;

    Mysql类 <?php /** * Mysql类 */ class Mysql{ private static $link = null;//数据库连接 /** * 私有的构造方法 */ pr ...

  6. django 分页(2) 使用类 页码显示

    django 分页显示页码 views.py 显示11页码 ) < 起始位置 - 10总页数 else 总页数 > IF 当前页 小于 起始位置 结束页 IF 当前页 大于 IF 如果结束 ...

  7. 封装好的PHP分页类,简单好用--在开源看到的,取回来自己用

    class Pagination  独立分页类 调用方式: $pagenation = new Pagination( 4, 10, 200 ); // 4(第一个参数) = currentPage, ...

  8. django 分页组件

      一.仿django分页功能自己实现 urls.py 1 2 3 4 5 6 7 8 9 from django.conf.urls import url from django.contrib i ...

  9. Django分页的实现

    Django分页的实现 Django ORM  分页介绍 分页是网页浏览中常见到的一种形式,在数据量较大时,一个页面显示不全,采取分割数据由用户选择进行显示的方式. 基本实现 技术点 通过切片得到数据 ...

随机推荐

  1. Mac 安装GCC

    OS X上安装Homebrew和GCC的图文攻略 2016年08月31日 11:21:27 白马负金羁 阅读数:11380 标签: OS XGCCHomebrew 更多 个人分类: 应用技巧   版权 ...

  2. 自动创建orcl表

    using System;using System.Collections.Generic;using System.Data;using System.Linq;using System.Text; ...

  3. Nginx搭建后,图片存储在Tomcat上,前端无法回显图片问题

    一.Nginx与Tomcat连接搭建的环境,Nginx设置了前端的访问路径为 (1)前端代码配置: root /usr/local/nginx/html; index index.html index ...

  4. 布局分析002:入门级的CSS导航弹出菜单

    这种弹出菜单非常有意思,也有记录的意义,甚至可以说,掌握了这种弹出菜单,基本上CSS掌握的差不多. 主要涉及下面三个重要知识: CSS的继承性质. relative absolute定位. 子选择符& ...

  5. ASIHTTPRequest-Cookie的使用[转]

    ASIHTTPRequest允许你使用全局存储来和所有使用CFNetwork或者NSURLRequest接口的程序共享cookie. 如果设置useCookiePersistence为YES(默认值) ...

  6. .NET基础 (13)IFormattable和IformatProvider的使用

    IFormattable和IformatProvider的使用1 如何使用IFormattable接口实现格式化输出2 如何告诉类型格式化输出的方式 IFormattable和IformatProvi ...

  7. ZOJ2201 No Brainer 2017-04-16 19:21 54人阅读 评论(0) 收藏

    No Brainer Time Limit: 2 Seconds      Memory Limit: 65536 KB Zombies love to eat brains. Yum. Input ...

  8. kali下firefox的安装

    在kali的系统中自带了一个firefox分支下的浏览器Iceweasel(Iceweasel是Mozilla Firefox浏览器的Debian再发布版),但是怎么说也配不上kali的强悍气势.还是 ...

  9. eclipse 高效快捷键大全

    一个Eclipse骨灰级开发者总结了他认为最有用但又不太为人所知的快捷键组合.通过这些组合可以更加容易的浏览源代码,使得整体的开发效率和质量得到提升. 1. ctrl+shift+r:打开资源 这可能 ...

  10. 开源WebGIS实施方案(五):基于SLD实现图层符号化及其应用

    SLD概述 SLD(OpenGIS® Styled Layer Descriptor):图层样式注记.其当前版本是1.1.0.SLD是一种描述地图图层样式的标准,一般用于WMS中的图层符号化. 说白了 ...