分页简介

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

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

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

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

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

例子:

用类的方式:

在后台进行分页

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. Unbuntu 16.04 英文环境安装中文输入法

    ubuntu 16.04 使用的是ibus输入系统,没有预装中文输入法,你要自己安装一下.以中文拼音输入法为例:1.sudo apt install ibus-pinyin2.sudo apt ins ...

  2. 牛人的blog,关于推荐,topic model的

    http://blog.csdn.net/zhoubl668?viewmode=list

  3. 深入理解Spring Redis的使用 (七)、Spring Redis 使用 jackson序列化 以及 BaseDao代码

    之前在介绍Spring Redis进行存储的时候,都是通过RedisTemplate中的defaultSerializer,即JdkSerializationRedisSerializer.通过Jdk ...

  4. 如何利用GitHub搜索敏感信息

    如何利用GitHub搜索敏感信息 背景: 最近总是能听到同事说在GitHub上搜到某个敏感信息,然后利用该信息成功的检测并发现某个漏洞,最后提交到对应的SRC(安全应急响应中心)换点money.顿时心 ...

  5. [Swift]LeetCode1001. 网格照明 | Grid Illumination

    On a N x N grid of cells, each cell (x, y) with 0 <= x < N and 0 <= y < N has a lamp. In ...

  6. websocket+rabbitmq实战

    1. websocket+rabbitmq实战 1.1. 前言   接到的需求是后台定向给指定web登录用户推送消息,且可能同一账号会登录多个客户端都要接收到消息 1.2. 遇坑 基于springbo ...

  7. 微信小程序实战–集阅读与电影于一体的小程序项目(八)

    31.电影详情页面 movie-template.wxml <view class="movie-container" catchtap="onMovieTap&q ...

  8. SpringBoot+Elasticsearch

    1.  前言 1.1.  集成方式 Spring Boot中集成Elasticsearch有4种方式: REST Client Jest Spring Data Spring Data Elastic ...

  9. springboot+springcloud集成jar

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  10. leetcode — convert-sorted-list-to-binary-search-tree

    import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Source : https://o ...