CRM之分页
分页简介
分页功能在网页中是非常常见的一个功能,其作用也就是将数据分割成多个页面来进行显示。
使用场景: 当取到的数据量达到一定的时候,就需要使用分页来进行数据分割。
当我们不使用分页功能的时候,会面临许多的问题:
客户端的问题: 如果数据量太多,都显示在同一个页面的话,会因为页面太长严重影响到用户的体验,也不便于操作,也会出现加载太慢的问题。
服务端的问题: 如果数据量太多,可能会造成内存溢出,而且一次请求携带的数据太多,对服务器的性能也是一个考验。
例子:
用类的方式:
在后台进行分页
1.首先在项目根目录下创建一个utils包, 创建pagination.py文件

# pagination.py
class Pagination:
def __init__(self, page_num, all_count, per_num=11, max_page=10):
"""
:param page_num: 当前页数
:param all_count: 总数据量
:param per_num: 每页显示的数据量
:param max_page: 显示最大页码数, 默认为10页
"""
# 获取页码
try:
self.page_num = int(page_num)
if self.page_num <= 0:
self.page_num = 1
except Exception as e:
self.page_num = 1
# 每页显示的数据
self.per_num = per_num
# 总数据量
self.all_count = all_count
# 总页数
# divmod(a, b) 返回一个包含商和余数的元组(a // b, a % b)。
self.page_count, more = divmod(all_count, per_num)
if more:
self.page_count += 1
# 显示最大页码数
self.max_page = max_page
self.half_page = max_page // 2
@property
def page_html(self):
if self.page_count < self.max_page:
page_start = 1
page_end = self.page_count
else:
if self.page_num <= self.half_page:
page_start = 1
page_end = self.max_page
elif self.page_num + self.half_page >= self.page_count:
page_start = self.page_count - self.max_page + 1
page_end = self.page_count
else:
page_start = self.page_num - self.half_page #
page_end = self.page_num + self.half_page # 7 +
page_list = []
# 控制页数不能低于1
if self.page_num == 1:
page_list.append('<li class="disabled"><a href="?page={}">上一页</a></li>'.format(self.page_num))
else:
page_list.append('<li><a href="?page={}">上一页</a></li>'.format(self.page_num - 1))
for page in range(page_start, page_end + 1):
if page == self.page_num:
page_list.append('<li class="active"><a href="?page={}">{}</a></li>'.format(page, page))
else:
page_list.append('<li><a href="?page={}">{}</a></li>'.format(page, page))
# 控制不能超过总页数
if self.page_num == self.page_count:
page_list.append('<li class="disabled"><a href="?page={}">下一页</a></li>'.format(self.page_count))
else:
page_list.append('<li><a href="?page={}">下一页</a></li>'.format(self.page_num + 1))
return ''.join(page_list)
@property
def start(self):
return (self.page_num - 1) * self.per_num
@property
def end(self):
return self.page_num * self.per_num
# views.py from django.shortcuts import render, reverse, redirect, HttpResponse from utils.pagination import Pagination # 模拟数据
users = [{'name': 'Jerry{}'.format(i), 'pwd': ''} for i in range(1, 302)] def user_list(request):
"""
一页显示20 第1页 0 20
第2页 20 40 n (n-1)*20 20*n :param request:
:return:
"""
page = Pagination(request.GET.get('page', ''), len(users))
return render(request, 'user_list.html',{'users':users[page.start:page.end],'page_html':page.page_html })
# user_list.html 网页文件
{% extends 'layout.html' %} # 继承了一个模板 {% block content %}
<table class="table table-hover table-bordered">
{% for foo in users %}
<tr>
<td>{{ foo.name }}</td>
<td>{{ foo.pwd }}</td>
</tr>
{% endfor %}
</table>
<nav aria-label="Page navigation">
<ul class="pagination"> {{ page_html|safe }}
</ul>
</nav> {% endblock %}
效果图:

函数的方式:
# views.py
# 模拟数据
users = [{'name': 'Jerry{}'.format(i), 'pwd': ''} for i in range(1, 302)]
def user_list(request):
"""
一页显示20 第1页 0 20
第2页 20 40 n (n-1)*20 20*n :param request:
:return:
"""
# 获取页码
try:
page_num = int(request.GET.get('page', '1'))
if page_num <= 0:
page_num = 1
except Exception as e:
page_num = 1
# 每页显示的数据
per_num = 10 # 总数据量
all_count = len(users) # 总页数
# divmod(a, b) 返回一个包含商和余数的元组(a // b, a % b)。
page_count, more = divmod(all_count, per_num)
if more:
page_count += 1 # 显示最大页码数
max_page = 11
half_page = max_page // 2 # python中循环
if page_count < max_page:
page_start = 1
page_end = page_count
else:
if page_num <= half_page:
page_start = 1
page_end = max_page
elif page_num + half_page >= page_count:
page_start = page_count - max_page + 1
page_end = page_count
else:
page_start = page_num - half_page # 2
page_end = page_num + half_page # 7 + page_list = []
# 控制页数不能低于1
if page_num == 1:
page_list.append('<li class="disabled"><a href="?page={}">上一页</a></li>'.format(page_num))
else:
page_list.append('<li><a href="?page={}">上一页</a></li>'.format(page_num - 1)) for page in range(page_start, page_end + 1):
page_list.append('<li><a href="?page={}">{}</a></li>'.format(page, page)) # 控制不能超过总页数
if page_num == page_count:
page_list.append('<li class="disabled"><a href="?page={}">下一页</a></li>'.format(page_count))
else:
page_list.append('<li><a href="?page={}">下一页</a>>下一页</li>'.format(page_num + 1))
page_html = ''.join(page_list)
return render(request, 'user_list.html', {"users": users[(page_num - 1) * per_num:page_num * per_num],
'page_html': mark_safe(page_html)})
# user_list.html
{% extends 'layout.html' %}
{% block content %}
<table class="table table-hover table-bordered">
{% for foo in users %}
<tr>
<td>{{ foo.name }}</td>
<td>{{ foo.pwd }}</td>
</tr>
{% endfor %}
</table>
<nav aria-label="Page navigation">
<ul class="pagination">
{{ page_html }}
</ul>
</nav>
{% endblock %}
CRM之分页的更多相关文章
- Java中分页功能源码实例
一.源码(后附使用说明) package com.zhiyou100.crm.util; /** * 分页功能 * @author YangXianSheng * */ public class Pa ...
- 老男孩Python全栈第2期+课件笔记【高清完整92天整套视频教程】
点击了解更多Python课程>>> 老男孩Python全栈第2期+课件笔记[高清完整92天整套视频教程] 课程目录 ├─day01-python 全栈开发-基础篇 │ 01 pyth ...
- 巨蟒python全栈开发-第11阶段 ansible_project2
一个NB的网站: https://www.toolfk.com/ CDN:将用户的需求送到最近的节点:内容分发网络 有些是专门做CDN的工具 常用的markdown是需要知道的,短信有字数限制. we ...
- crm 数据展示 和分页思想(一)
1. 数据的展示 数据通过ORM查询出来 对象列表 QuerySet 1. 普通的字段 对象.字段名 ——> 数据库中的值 <td>{{ customer.phone }}</ ...
- Django之CRM项目Day3-客户展示及分页
1.展示客户 模板的查找顺序: 先找全局的templates--> 按照app的注册顺序找templates中的文件 使用admin添加数据: 创建超级用户 python manage.py ...
- crm --- 1.admin , 展示列表 和 分页
一.admin (创建超级用户) 1.注册: 1.创建一个超级管理员,使用如下命令: python manage.py createsuperuser 2.输入打算使用的登录名: username:m ...
- S/4HANA和CRM Fiori应用的搜索分页实现
在我的博客Paging Implementation in S/4HANA for Customer Management 我介绍了S/4HANA for Customer Management里采用 ...
- Django项目:CRM(客户关系管理系统)--80--70PerfectCRM实现CRM业务流程(bpm)课程排行分页
# coursetop_views.py # ————————64PerfectCRM实现CRM课程排名详情———————— #————班级学生详情——#计算#{学员ID:分数}——#计算 #{学员I ...
- Django项目:CRM(客户关系管理系统)--79--69PerfectCRM实现CRM业务流程(bpm)学生讲师分页
# student_views.py # ————————60PerfectCRM实现CRM学生上课记录———————— from django.shortcuts import render #页面 ...
随机推荐
- 算法与数据结构(十二) 散列(哈希)表的创建与查找(Swift版)
散列表又称为哈希表(Hash Table), 是为了方便查找而生的数据结构.关于散列的表的解释,我想引用维基百科上的解释,如下所示: 散列表(Hash table,也叫哈希表),是根据键(Key)而直 ...
- [Swift]LeetCode212. 单词搜索 II | Word Search II
Given a 2D board and a list of words from the dictionary, find all words in the board. Each word mus ...
- python之pickle模块
1 概念 pickle是python语言的标准模块,安装python后以包含pickle库,不需要再单独安装. pickle提供了一种简单的持久化功能,可以将对象以文件的形式存放在磁盘上. pickl ...
- vue-textarea 自适应高度
需求简介 一个搜索页面,上面输入框,下面列表展示搜索到的结果. 重点是:产品要求搜索框默认显示一行,当输入的文字超过一行时,输入框的高度会随着改变,直到输入完毕. 解决思路设想 本想利用textare ...
- 工作随笔—Java容器基础知识分享(持有对象)
1. 概述 通常,程序总是运行时才知道的根据某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型,为解决这个普遍的编程问题:需要在任意时刻和任意位置创建任意数量的对象,所以,就 ...
- JS设计模式之单例模式
单例模式 单例模式的定义是:保证一个类只有一个实例,并提供一个访问它的全局访问点.比如说购物车,在一个商城中,我们只需要一个购物车,购物车在整个商城中是唯一的,不需要多次创建,即使多次点击购物车按钮, ...
- 小技巧,把Markdown文本发布到微信公众号文章
估计很多人都是这样,平常工作在github,等到有成果要发布,又要写微信公众号. github用Markdown,微信公众号,至少截止今天,还是沿用富文本的方式.不是说富文本不好,但每次精心撰写的内容 ...
- [Leetcode]669 Trim a Binary Search Tree
Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so that a ...
- 《深入java虚拟机》读书笔记之垃圾收集器与内存分配策略
前言 该读书笔记用于记录在学习<深入理解Java虚拟机--JVM高级特性与最佳实践>一书中的一些重要知识点,对其中的部分内容进行归纳,或者是对其中不明白的地方做一些注释.主要是方便之后进行 ...
- Django的静态资源
如果你的静态资源是某个APP专属,那么就在这个APP目录下建立一个static目录,就像上图report这个APP中的static目录.当浏览这个APP的网页时它会从这里去找资源,当然,它首先会从共用 ...