django项目一 分页器(前端分页和后端分页区别)
1. 客户信息展示
1. 母版和继承
{% extends 'layout'%}
{% load static%}
{% static '文件路径' %}
block css js content
2. 内容显示
普通字段 {{ customer.qq }}
choices {{ customer.get_class_type_display }}
多对多 定义方法 返回字符串
显示状态 定义方法 返回HTML代码段 mark_safe
2. 分页
from django.utils.safestring import mark_safe # 字符串不进行转义
from django.utils.html import format_html
前端分页和后端分页
前端分页一般用于数据量较小的情况,一次请求把数据全部从后端请求回来
后端分页适用于数据量偏大时的情况,减小请求传输压力
前端分页
前端分页一般用于数据量较小的情况,一次请求把数据全部从后端请求回来。下面是vue-element-ui的分页组件写法:
需要注意的是:
当前页展示的数据与总数据的关系
let show = this.contactsInfo.slice(this.sizePerPage * (this.activePage - 1), this.sizePerPage * (this.activePage));
当每页条数改变时,当前页设置为首页。防止每页条数变大时,当前页时不存在的页数。
后端分页
后端分页适用于数据量偏大时的情况,减小请求传输压力。前端需要将每页条数和当前页传给后端,后端根据条件查询出数据再传给前端,包括总条数、当前页、每页多少条数据等。
前端显示的当前页和每页多少条数据由后端传回的数据决定,否则出现改变前端参数,还未发请求时,页码的错乱。
当改变每页多少条时,当前页参数置为首页。
template包中建立pagination.py
class Pagination:
def __init__(self, page, all_count, per_num=3, max_show=11):
try:
page = int(page)
if page <= 0:
page = 1
except Exception as e:
page = 1
self.page = page
self.all_count = all_count
self.per_num = per_num
self.max_show = max_show
# 总页码数
self.page_num, more = divmod(all_count, per_num)
if more:
self.page_num += 1
# 最多显示页码数
half_show = max_show // 2
if self.page_num < max_show:
# 总页码数不够 最大显示页码数
self.page_start = 1
self.page_end = self.page_num
else:
# 能显示超过最大显示页码数
if page <= half_show:
# 处理左边的极值
self.page_start = 1
self.page_end = max_show
elif page + half_show > self.page_num:
# 处理右边的极值
self.page_start = self.page_num - max_show + 1
self.page_end = self.page_num
else:
# 正常的情况
self.page_start = page - half_show
self.page_end = page + half_show
@property
def start(self):
return (self.page - 1) * self.per_num
@property
def end(self):
return self.page * self.per_num
@property
def page_html(self):
li_list = []
if self.page == 1:
li_list.append('<li class="disabled" ><a> << </a></li>')
else:
li_list.append('<li ><a href="?page={}"> << </a></li>'.format(self.page - 1))
for i in range(self.page_start, self.page_end + 1):
if self.page == i:
li_list.append('<li class="active"><a href="?page={}">{}</a></li>'.format(i, i))
else:
li_list.append('<li><a href="?page={}">{}</a></li>'.format(i, i))
if self.page == self.page_num:
li_list.append('<li class="disabled" ><a> >> </a></li>')
else:
li_list.append('<li ><a href="?page={}"> >> </a></li>'.format(self.page + 1))
return ''.join(li_list)
分页器
views文件中
from django.shortcuts import render from CRM import models
from CRM.tools.pagination import Pagination def customer_list(request):
# 从数据库中拿取客户对象
customer_obj = models.Customer.objects.all()
# print(len(customer_obj)) # 实例化分页器的类, 传入参数: 1: 当前页 2: 对象数量 3: 每页展示条数 4: 显示页面个数
pager = Pagination(request.GET.get('page', ''), len(customer_obj), per_num=2, max_show=3)
print(pager.page_end)
return render(request, 'customer_list.html', {
"customer_obj": customer_obj[pager.start:pager.end],
'page_html': pager.page_html,
'last_page': pager.page_num}
)
分页器使用
HTML中 包含首页,尾页
<nav aria-label="Page navigation" style="text-align: center">
<button style="
border: none;
border-radius:4px;
padding:7px 12px;
background-color: #f2f4f2;
vertical-align: middle
">
<a href="?page=1/">首页</a>
</button> <ul class="pagination" style="vertical-align: middle">
{{ page_html|safe }}
</ul> <button style="
border: none;
border-radius:4px;
padding:7px 12px;
background-color: #f2f4f2;
vertical-align: middle
">
<a href="?page={{ last_page }}">尾页</a>
</button>
</nav>
模板中使用
django项目一 分页器(前端分页和后端分页区别)的更多相关文章
- EasyUI表格DataGrid前端分页和后端分页的总结
Demo简介 Demo使用Java.Servlet为后台代码(数据库已添加数据),前端使用EasyUI框架,后台直接返回JSON数据给页面 1.配置Web.xml文件 <?xml version ...
- vue2.0+Element UI 表格前端分页和后端分页
之前写过一篇博客,当时对element ui框架还不太了解,分页组件用 html + css 自己写的,比较麻烦,而且只提到了后端分页 (见 https://www.cnblogs.com/zdd20 ...
- jQuery--dataTable 前端分页与后端分页 及遇到的问题
(1)区别 前端分页:一次性把所有数据全都放在前端,由前端进行处理:适合请求的数据量不大的情况 后端分页:服务器模式,所有的分页,搜索,排序等操作在服务器端完成,然后前端去请求数据:适合量大的情况 ( ...
- django项目分页
测试版本 代码: # 测试分页users=[{'name':'alex{}'.format(i),'pwd':'aaa{}'.format(i)}for i in range(1,302)] def ...
- 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(4)
chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...
- Django项目:CRM(客户关系管理系统)--22--14PerfectCRM实现King_admin分页的省略显示
{#table_data_list.html#} {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#} {% extends 'king_m ...
- Django项目:CRM(客户关系管理系统)--21--13PerfectCRM实现King_admin分页页数
{#table_data_list.html#} {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#} {% extends 'king_m ...
- 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(3)
chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...
- 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(2)
chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...
随机推荐
- JS实现网页背景旋转缩放轮播效果
实现效果:效果预览 css代码: .switch_images { display: inline-block; margin:; padding:; width: 100%; height: 100 ...
- linux源码安装的步骤
源码安装的过程中多多少少会遇到问题,在此仅简述一下安装的步骤,具体安装的过程中遇到的问题,具体解决. 安装步骤: 1.获取源码 name.gz 2.解包 tar -xvf name.gz (cd到包解 ...
- JavaScript Boolean( new Boolean(false) ) 其实是true
Boolean类型是JavaScript原始数据类型(primitive type)之一:常用来表示 真或假,是或否:这个类型只有两个值:保留字true和false 一般用于控制语句:如下 if(Bo ...
- ES练习代码
package elasticsearch; import java.util.HashMap; import java.util.List; import java.util.Map; import ...
- C# 算法系列一基本数据结构
一.简介 作为一个程序员,算法是一个永远都绕不过去的话题,虽然在大学里参加过ACM的比赛,没记错的话,浙江赛区倒数第二,后来不知怎么的,就不在Care他了,但是现在后悔了,非常的后悔!!!如果当时好好 ...
- Python学习--02输入和输出、运算符
命令行输入 x = input("Please input x:") y = raw_input("Please input x:") 使用input和raw_ ...
- poi导出联动下拉选择的excel
最近碰到一个功能, 觉得可以记录下来. 在web中, 经常会碰到上下级的数据, 或者是联动数据, 比如省市联动. 那么在导入数据的时候, 是否可以在动态生成的模板中, 加入联动限制呢. 一. 数据准备 ...
- Java程序读取Properties文件
一.如果将properties文件保存在src目录下 1.读取文件代码如下: /** * 配置文件为settings.properties * YourClassName对应你类的名字 * / pri ...
- BackgroundWorker简单实用(简便的异步操作)
微软提供了一个快捷使用多线程的帮助类BackgroundWorker,能够快速创建一个新的线程,并能报告进度,暂停,以及在线程完成后处理别的任务. 1.BackgroundWorker类介绍 1.1. ...
- Maven 进阶
一.Maven 版本管理 Maven 的推荐版本号约定为:主版本号.次版本号.增量版本号-<里程碑版本> 开发中的版本要以 -SNAPSHOT 结尾,因为这种快照版本是支持 jar 包被覆 ...