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项目一 分页器(前端分页和后端分页区别)的更多相关文章

  1. EasyUI表格DataGrid前端分页和后端分页的总结

    Demo简介 Demo使用Java.Servlet为后台代码(数据库已添加数据),前端使用EasyUI框架,后台直接返回JSON数据给页面 1.配置Web.xml文件 <?xml version ...

  2. vue2.0+Element UI 表格前端分页和后端分页

    之前写过一篇博客,当时对element ui框架还不太了解,分页组件用 html + css 自己写的,比较麻烦,而且只提到了后端分页 (见 https://www.cnblogs.com/zdd20 ...

  3. jQuery--dataTable 前端分页与后端分页 及遇到的问题

    (1)区别 前端分页:一次性把所有数据全都放在前端,由前端进行处理:适合请求的数据量不大的情况 后端分页:服务器模式,所有的分页,搜索,排序等操作在服务器端完成,然后前端去请求数据:适合量大的情况 ( ...

  4. django项目分页

    测试版本 代码: # 测试分页users=[{'name':'alex{}'.format(i),'pwd':'aaa{}'.format(i)}for i in range(1,302)] def ...

  5. 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(4)

    chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...

  6. Django项目:CRM(客户关系管理系统)--22--14PerfectCRM实现King_admin分页的省略显示

    {#table_data_list.html#} {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#} {% extends 'king_m ...

  7. Django项目:CRM(客户关系管理系统)--21--13PerfectCRM实现King_admin分页页数

    {#table_data_list.html#} {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#} {% extends 'king_m ...

  8. 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(3)

    chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...

  9. 对一个前端使用AngularJS后端使用ASP.NET Web API项目的理解(2)

    chsakell分享了一个前端使用AngularJS,后端使用ASP.NET Web API的项目. 源码: https://github.com/chsakell/spa-webapi-angula ...

随机推荐

  1. MariaDB 视图与触发器(11)

    MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可MariaDB的目的是完全兼容MySQL,包括API和命令行,MySQL由于现在闭源了,而能轻松成为MySQ ...

  2. [POI2015]LOG(树状数组)

    今天考试考了这题,所以来贡献\([POI2015]LOG\)的第一篇题解.代码略丑,调了快三个小时才调出来\(AC\)代码. 对于这种小清新数据结构题,所以我觉得树状数组才是这道题的正确打开方式. 首 ...

  3. Swift5 语言参考(六) 声明

    一个声明引入了一个新的名称或构建到你的程序.例如,您使用声明来引入函数和方法,引入变量和常量,以及定义枚举,结构,类和协议类型.您还可以使用声明来扩展现有命名类型的行为,并将符号导入到其他地方声明的程 ...

  4. Windows Service 项目中 Entity Framework 无法加载的问题

    Windows Service 项目引用了别的类库项目,别的项目用到了 Entity Framework(通过Nuget引入),但是我的 Windows Service 无法开启,于是我修改了 App ...

  5. Java - Junit单元测试框架

    简介 Junit : http://junit.org/ JUnit是一个开放源代码的Java语言单元测试框架,用于编写和运行可重复的测试. 多数Java的开发环境都已经集成了JUnit作为单元测试的 ...

  6. day 71 crm(8) 权限组件的设置,以及权限组件的应用

    ---恢复内容开始--- 前情提要: strak 组件是增删改查组件 , 生活中,需求权限组件,  不足: 1,前后端不分离,   2, 空url也会刷新界面,造成资源浪费   3,如果角色忘记设置权 ...

  7. W,b的初始化和几种激活函数

    权重W不能全部初始化为0,原因很简单,我们可以自己在本子上推导一下,假设现有一个含有一个隐藏层,隐藏层含有两个神经元初始输入为两个向量的网络,如果权重初始化全部为0,那么,第一层的输出,会和第二层的输 ...

  8. 传染病传播模型(SIS)Matlab代码

    function spreadingability=sir(A,beta,mu) for i=1:length(A) for N=1:50%随机次数 InitialState=zeros(length ...

  9. ASP.NET 上传大文件(原创)

    问题描述 需要在网站中上传文件,但是当文件大小太大的时候IIS会拒绝连接,导致用户看到不友好的错误界面. 解决方法 1.服务器端处理 在globle.asax中的protected void Appl ...

  10. Maven启用代理服务器访问

    0.什么叫代理服务器? 代理服务器英文全称是(Proxy Server),其功能就是代理网络用户去取得网络信息.形象的说:它是网络信息的中转站. 代理服务器就好象一个大的Cache,这样就能显著提高浏 ...