分页简介

  分页功能在网页中是非常常见的一个功能,其作用也就是将数据分割成多个页面来进行显示。

  使用场景: 当取到的数据量达到一定的时候,就需要使用分页来进行数据分割。

  当我们不使用分页功能的时候,会面临许多的问题:

    客户端的问题: 如果数据量太多,都显示在同一个页面的话,会因为页面太长严重影响到用户的体验,也不便于操作,也会出现加载太慢的问题。

    服务端的问题: 如果数据量太多,可能会造成内存溢出,而且一次请求携带的数据太多,对服务器的性能也是一个考验。

例子:

用类的方式:

在后台进行分页

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之分页的更多相关文章

  1. Java中分页功能源码实例

    一.源码(后附使用说明) package com.zhiyou100.crm.util; /** * 分页功能 * @author YangXianSheng * */ public class Pa ...

  2. 老男孩Python全栈第2期+课件笔记【高清完整92天整套视频教程】

    点击了解更多Python课程>>> 老男孩Python全栈第2期+课件笔记[高清完整92天整套视频教程] 课程目录 ├─day01-python 全栈开发-基础篇 │ 01 pyth ...

  3. 巨蟒python全栈开发-第11阶段 ansible_project2

    一个NB的网站: https://www.toolfk.com/ CDN:将用户的需求送到最近的节点:内容分发网络 有些是专门做CDN的工具 常用的markdown是需要知道的,短信有字数限制. we ...

  4. crm 数据展示 和分页思想(一)

    1. 数据的展示 数据通过ORM查询出来 对象列表 QuerySet 1. 普通的字段 对象.字段名 ——> 数据库中的值 <td>{{ customer.phone }}</ ...

  5. Django之CRM项目Day3-客户展示及分页

    1.展示客户 模板的查找顺序: ​ 先找全局的templates--> 按照app的注册顺序找templates中的文件 使用admin添加数据: 创建超级用户 python manage.py ...

  6. crm --- 1.admin , 展示列表 和 分页

    一.admin (创建超级用户) 1.注册: 1.创建一个超级管理员,使用如下命令: python manage.py createsuperuser 2.输入打算使用的登录名: username:m ...

  7. S/4HANA和CRM Fiori应用的搜索分页实现

    在我的博客Paging Implementation in S/4HANA for Customer Management 我介绍了S/4HANA for Customer Management里采用 ...

  8. Django项目:CRM(客户关系管理系统)--80--70PerfectCRM实现CRM业务流程(bpm)课程排行分页

    # coursetop_views.py # ————————64PerfectCRM实现CRM课程排名详情———————— #————班级学生详情——#计算#{学员ID:分数}——#计算 #{学员I ...

  9. Django项目:CRM(客户关系管理系统)--79--69PerfectCRM实现CRM业务流程(bpm)学生讲师分页

    # student_views.py # ————————60PerfectCRM实现CRM学生上课记录———————— from django.shortcuts import render #页面 ...

随机推荐

  1. JavaScript 异步编程的前世今生(上)

    前言 提到 JavaScript 异步编程,很多小伙伴都很迷茫,本人花费大约一周的业余时间来对 JS 异步做一个完整的总结,和各位同学共勉共进步! 目录 part1 基础部分 什么是异步 part2 ...

  2. The algorithm learning of sort which include Bubblesort,Insertsort,Quicksort and Mergesort.

    Notice : these algorithms achieved by Java. So,let's going to it. firstly, what is Bubblesort? why w ...

  3. 12.Git分支-推送(push)、跟踪分支、拉取(pull)、删除远程分支

    1.推送 本地的分支并不会自动与远程仓库同步,你可以显示的向远程仓库推送你的分支.例如你在本地创建了一个dev分支,你想其他的人和你一样在dev之下进行工作,可以使用 git push <rem ...

  4. [Abp 源码分析]十五、自动审计记录

    0.简介 Abp 框架为我们自带了审计日志功能,审计日志可以方便地查看每次请求接口所耗的时间,能够帮助我们快速定位到某些性能有问题的接口.除此之外,审计日志信息还包含有每次调用接口时客户端请求的参数信 ...

  5. Python内置函数(43)——min

    英文文档: min(iterable, *[, key, default]) min(arg1, arg2, *args[, key]) Return the smallest item in an ...

  6. 【从零开始自制CPU之学习篇05】总线

    总线定义:总线(Bus)是计算机各种功能部件之间传送信息的公共通信干线,它是由导线组成的传输线束, 按照计算机所传输的信息种类,计算机的总线可以划分为数据总线.地址总线和控制总线,分别用来传输数据.数 ...

  7. Vue生命周期详解

    Vue所有的生命周期钩子自动绑定在this上下文到实例中,因此你可以访问数据,对属性和方法进行运算.这意味着你不能使用箭头函数来定义一个生命周期方法.这是因为箭头函数绑定了父上下文,因此this与你期 ...

  8. C++ 动态生成对象

    1.啰嗦一下 说起C++,很多人都觉着难学,其实我也是这么觉着的,在这个移动端火到爆的时代,我都想改行了,移动端做东西那都是现有的第三方库,拿来就可以用,而且稳定性好,开发速度快,而且最关键的是出东西 ...

  9. 『ice 离散化广搜』

    ice(USACO) Description Bessie 在一个冰封的湖面上游泳,湖面可以表示为二维的平面,坐标范围是-1,000,000,000..1,000,000,000. 湖面上的N(1 & ...

  10. 使用ML.NET预测纽约出租车费

    有了上一篇<.NET Core玩转机器学习>打基础,这一次我们以纽约出租车费的预测做为新的场景案例,来体验一下回归模型. 场景概述 我们的目标是预测纽约的出租车费,乍一看似乎仅仅取决于行程 ...