crm 数据展示 和分页思想(一)
1. 数据的展示
数据通过ORM查询出来 对象列表 QuerySet
1. 普通的字段
对象.字段名 ——》 数据库中的值
<td>{{ customer.phone }}</td>
2. choices
((1,'男'))
对象.字段名 ——》 数据库中的值 1
对象.get_字段名_display() ——》 数据库中的值对应的显示值 男
<td>{{ customer.get_source_display }}</td>
3. 外键
对象.外键 ——》 关联的对象 定义 __str__ __repr__
对象.外键.字段名
4. 自定义方法
多对多:
#显示自定义已报班级
在models.py中
def show_class(self):
return ' | '.join([str(i) for i in self.class_list.all()])
<td>{{ customer.show_class }}</td>
自定义显示HTML代码:
from django.utils.safestring import mark_safe def show_status(self): status_color = { 'signed': 'green',
'unregistered': '#208c72',
'studying': 'yellow',
'paid_in_full': 'blue',
} return mark_safe('<span style="background-color: {};color: white;padding: 2px">{}</span>'.format(
status_color.get(self.status), self.get_status_display()))
前端应用
<td>{{ customer.show_status }}</td>
2. 分页
总的是思想 就是 拿到总页面数除分页数 得到做大页面数,对最大页面数 进行判断规定显示几个页面
具体算法 如最大页面数是11 除余2 得到5 如我当前页数是7 就用7-5得到开头 7+5等于结尾
2 12 =10 因为开头2也算就11
users = [{'name': 'alex{}'.format(i), 'pwd': ''} for i in range(1, 302)] def fycustomer_list(request):
# Customer_all=models.Customer.objects.all()
'''
第一页 0 20
第2页 20 40
n (n-1)*20 开始 20*n结尾
>>> divmod(9,2)
(4, 1)
>>> divmod(9,2)[0]
4
>>> divmod(9,2)[1]
1
'''
try:
page_num = int(request.GET.get('page', ''))
if page_num <= 0:
page_num = 1
except Exception as e: # 输入字符串也等于一
page_num = 1
per_num = 10
# 总数量
all_count = len(users)
# 总页码数 除分页数
page_count, more = divmod(all_count, per_num)
if more: # 如果有余数就+1页
page_count += 1
# 最大页码数 获取的页面除二减去 用于开头
max_show = 11
half_show = max_show // 2
# #7-5
# page_start=page_num-half_show
# page_end=page_num+half_show #7+5
# 总页码数 < 最大显示页码数
if page_count < max_show:
page_start = 1
page_end = page_count
else:
# 处理左边极值
# 当前页小于等于一半
if page_num <= half_show:
page_start = 1
page_end = max_show
# 当前的数 +页码的一半 大于页码数
elif page_num + half_show >= page_count:
page_start = page_count - max_show + 1
page_end = page_count
else:
page_start = page_num - half_show # 7-5 11的一半
page_end = page_num + half_show # 7 + 5 12 page_list = []
if page_num == 1: # 第一页选的页码page_num
page_list.append('<li class="disabled"><a>上一页</a></li>')
else:
page_list.append('<li><a href="?page={}">上一页</a></li>'.format(page_num - 1, )) # 点击上一页-1
# print('aaaaa', page_start) for i in range(page_start, page_end + 1):
if i == page_num:
page_list.append('<li class="active"><a href="?page={}">{}</a></li>'.format(i, i)) # 等于就激活当前页面 其他继续显示
else:
page_list.append('<li><a href="?page={}">{}</a></li>'.format(i, i)) if page_num == page_count:
page_list.append('<li class="disabled"><a>下一页</a></li>')
else:
page_list.append('<li><a href="?page={}">下一页</a></li>'.format(page_num + 1, )) # 点击下一页+1 page_html = ''.join(page_list) return render(request, 'user_list.html', {'users': users[(page_num - 1) * per_num:per_num * page_num],
'page_html': page_html})
html
<table class="table table-hover table-bordered">
{% for user in users %}
<tr>
<td>{{ user.name }}</td>
<td>{{ user.pwd }}</td>
</tr>
{% endfor %}
</table> <nav aria-label="Page navigation">
<ul class="pagination">
{{ page_html|safe }}
</ul>
</nav>
封装成类
创建文件 utils 创建python文件pagination.py
class Pagination:
#当前页面数 总页码数 显示页码数 最大分页数
def __init__(self, page_num, all_count, per_num=10, max_show=11):
# 获取页码
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 # 总数据量
all_count = all_count # 总页码数
self.page_count, more = divmod(all_count, per_num)
if more:
self.page_count += 1 # 最大显示页码数
self.max_show = max_show
self.half_show = max_show // 2 @property
def page_html(self):
# 总页码数 < 最大显示页码数
if self.page_count < self.max_show:
page_start = 1
page_end = self.page_count
else:
# 处理左边极值
if self.page_num <= self.half_show:
page_start = 1
page_end = self.max_show
elif self.page_num + self.half_show >= self.page_count:
page_start = self.page_count - self.max_show + 1
page_end = self.page_count
else:
page_start = self.page_num - self.half_show #
page_end = self.page_num + self.half_show # 7 + 5 12 page_list = []
if self.page_num == 1:
page_list.append('<li class="disabled"><a>上一页</a></li>')
else:
page_list.append('<li><a href="?page={}">上一页</a></li>'.format(self.page_num - 1, )) for i in range(page_start, page_end + 1):
if i == self.page_num:
page_list.append('<li class="active"><a href="?page={}">{}</a></li>'.format(i, i))
else:
page_list.append('<li><a href="?page={}">{}</a></li>'.format(i, i)) if self.page_num == self.page_count:
page_list.append('<li class="disabled"><a>下一页</a></li>')
else:
page_list.append('<li><a href="?page={}">下一页</a></li>'.format(self.page_num + 1, )) return ''.join(page_list) @property
def start(self):
"""
切片的起始值
:return:
"""
return (self.page_num - 1) * self.per_num @property#封装成属性
def end(self):
"""
切片的终止值
:return:
"""
return self.page_num * self.per_num
关于 用户登陆 需要 session 认证 可以写个中间件 进行全局变量
创建middlewares 添加 auth.py
from django.utils.deprecation import MiddlewareMixin
from crm import models
from django.shortcuts import redirect, reverse
class AuthMiddleware(MiddlewareMixin):
def process_request(self, request):
if request.path_info in [reverse('login'), reverse('reg')]:#白名单
return
if request.path_info.startswith('/crm/admin/'):
return
pk = request.session.get('pk')
user = models.UserProfile.objects.filter(pk=pk).first()
# 没有登录 跳转至登录页面
if not user:
return redirect(reverse('login'))
request.user_obj = user
crm 数据展示 和分页思想(一)的更多相关文章
- layui数据表格使用(一:基础篇,数据展示、分页组件、表格内嵌表单和图片)
表格展示神器之一:layui表格 前言:在写后台管理系统中使用最多的就是表格数据展示了,使用表格组件能提高大量的开发效率,目前主流的数据表格组件有bootstrap table.layui table ...
- ASP.NET MVC 数据分页思想及解决方案代码
作为一个程序猿,数据分页是每个人都会遇到的问题.解决方案更是琳琅满目,花样百出.但基本的思想都是差不多的. 下面给大家分享一个简单的分页器,让初学者了解一下最简单的分页思想,以及在ASP.NET MV ...
- Android 仿淘宝头条竖直跑马灯式新闻标题及“分页思想
在淘宝App的首页中间位置,有一块小小的地方在不知疲倦地循坏滚动着头条标题(见下图的红框区域),这样的设计无疑能够在有限的手机屏幕上展示更丰富的内容.而实现这一功能需要用到的控件就是我在上一篇文章中提 ...
- Jqgrid入门-结合Struts2+json实现数据展示(五)
DEMO用的是ssh框架实现的,具体怎么搭建的就不多做说明了.分页表格的数据操作难点就是数据展现.至于增删改直接用hibernate原生的方法实现即可. 初步分析:表格要实现分页,那么 ...
- MVC模式下的数据展示:EasyUI的datagrid
我的数据库设计是一张老师表teacher,一张学生表student,一个教师对应多个学生,在学生一方建立外键; 还有一点想清楚,需要展示的数据是根据什么来的,是成功登陆的用户的id?还是直接展示所有的 ...
- 在DevExpress程序中使用PopupContainerEdit和PopupContainer实现数据展示
在一些数据的即时查询场景中,我们可能需要对输入信息进行模糊查询并进行选择,例如在一些文本输入场景,如输入某个站点编码或者设备编码,然后获取符合的列表供用户选择的场景,本篇随笔介绍在DevExpress ...
- PHP读取文件夹数据,并分页
protected function read_all ($dir){ // 确保目录有权限进入 if(!is_dir($dir)) return false; $handle = opendir($ ...
- 手把手教你写带登录的NodeJS爬虫+数据展示
其实在早之前,就做过立马理财的销售额统计,只不过是用前端js写的,需要在首页的console调试面板里粘贴一段代码执行,点击这里.主要是通过定时爬取https://www.lmlc.com/s/web ...
- django学习-27.admin管理后台里:对列表展示页面的数据展示进行相关优化
目录结构 1.前言 2.完整的操作步骤 2.1.第一步:查看ModelAdmin类和BaseModelAdmin类的源码 2.2.第二步:查看表animal对应的列表展示页面默认的数据展示 2.3.第 ...
随机推荐
- 0e开头的md5收集 --------PHP加密模块bug
————————————————md5加密—————————————— s878926199a s155964671a s214587387a s214587387a s878926199a s109 ...
- Redis可视化工具 Redis Desktop Manager
1.前言 从接触Redis也有两年,平时就使用它来做缓存层,它给我的印象就是很强大,内置的数据结构很齐全,加上Redis5.0的到来,新增了很多特色功能.而Redis5.0最大的新特性就是多出了一个数 ...
- pymysql的使用
import pymysql #打开数据库 (如果连接失败会报错)#db = pymysql.connect(host = '127.0.0.1', port = 3306, user = 'minb ...
- MySql 学习之路-聚合函数
下面是mysql 数据库中经常用到的聚合函数的简单实例 -- 创建学生表 create table student ( id int primary key auto_increment commen ...
- idea spring-boot总结
1. 按自己重新配置spring-boot pom点进 mybatis-spring-boot-starter ,在要改的里面 <version>3.4.4</version> ...
- SQL LEN() 函数
LEN() 函数 LEN 函数返回文本字段中值的长度. SQL LEN() 语法 SELECT LEN(column_name) FROM table_name SQL LEN() 实例 我们拥有下面 ...
- golang web实战之一(beego,mvc postgresql)
想写个小网站,听说MVC过时了,流行MVVM,但是看了一下gin+vue+axios方式,发现还有一堆知识点要掌握,尤其是不喜欢nodejs和javascript方式的写法.算了,还是用beego来写 ...
- 环境配置 mac安装bazel
brew cask install homebrew/cask-versions/java8 brew install bazel
- PHP利用多进程处理任务
PHP多进程一般应用在PHP_CLI命令行中执行php脚本,不要在web访问时使用. 多进程处理分解任务一般要比单进程更快. php查看是否安装多进程模块: php -m | grep pcn ...
- final和static关键字
1.如果类只有静态方法,可以将构造函数标记为private以避免被初始化: 2.常量同时标记为static和final,常量名全部大写,下划线连接: 3.final修饰一个成员变量(属性),必须要显示 ...