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.第 ...
随机推荐
- LeetCode算法题-Binary Number with Alternating Bits(Java实现)
这是悦乐书的第292次更新,第310篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第160题(顺位题号是693).给定正整数,检查它是否具有交替位:即它的二进制数的任意两 ...
- 浏览器仿EXCEL表格插件 版本更新 - 智表ZCELL产品V1.3发布
智表(zcell)是一款浏览器仿excel表格jquery插件.智表可以为你提供excel般的智能体验,支持双击编辑.设置公式.设置显示小数精度.下拉框.自定义单元格.复制粘贴.不连续选定.合并单元格 ...
- Myeclipse、eclipse安装lombok
Lombok简介 Lombok是一个可以通过简单的注解形式来帮助我们简化消除一些必须有但显得很臃肿的Java代码的工具,通过使用对应的注解,可以在编译源码的时候生成对应的方法.官方地址:https:/ ...
- Hbase技术笔记
一.Hbase介绍 二.Hbase的Region介绍 三.Hbase的写逻辑介绍 四.Hbase的故障恢复 五.Hbase的拆分和合并 如下ppt所示: 下面就来针对各个部分的内容来进行详细的介绍: ...
- java多线程(死锁,lock接口,等待唤醒机制)
一.Lock接口 常用方法 Lock提供了一个更加面对对象的锁,在该锁中提供了更多的操作锁的功能. 使用Lock接口,以及其中的lock()方法和unlock()方法替代同步,对电影院卖票案例中Tic ...
- ElasticSearch(七):Java操作elasticsearch基于smartcn中文分词查询
package com.gxy.ESChap01; import java.net.InetAddress; import org.elasticsearch.action.search.Search ...
- luogu P4842 城市旅行
嘟嘟嘟 好题,好题 刚开始突发奇想写了一个\(O(n ^ 2)\)暴力,结果竟然过了?!后来才知道是上传题的人把单个数据点开成了10s-- 不过不得不说我这暴力写的挺好看的.删边模仿链表删边,加边的时 ...
- Qt License 解读
对于桌面和移动平台应用 官方说明如下 Qt for Application Development lets you create applications for desktop and mobil ...
- Spring Security(三十一):9.6 Localization(本地化)
Spring Security supports localization of exception messages that end users are likely to see. If you ...
- python之shutil
''' shutil 用来处理 文件 文件夹 压缩包 的模块 ''' import shutil # 拷贝文件内容 shutil.copyfileobj(open('old.xml', 'r'), o ...