CRM客户关系管理系统(六)
第六章、排序和搜索功能开发
6.1.排序功能开发
(1)kingadmin_tags.py
@register.simple_tag
def get_sorted_column(column,sorted_column,forloop):
'''排序'''
if column in sorted_column: #如果这一列被排序了
#要判断上一次排序是按什么顺序,本次取反
last_sort_index = sorted_column[column]
if last_sort_index.startswith('-'):
#利用切片,去掉‘-’
this_time_sort_index = last_sort_index.strip('-')
else:
#加上 '-'
this_time_sort_index = '-%s'% last_sort_index
return this_time_sort_index
else:
return forloop
(2)kingadmin/views.py
def get_orderby_result(request,querysets,admin_class):
'''排序''' current_ordered_column = {}
#通过前端获取到要排序的字段的索引(是个字符串)
orderby_index = request.GET.get('_o')
if orderby_index:
#通过索引找到要排序的字段,因为索引有可能是负数也有可能是负数,要用绝对值,否则负值的时候取到了其它字段了
orderby_key = admin_class.list_display[abs(int(orderby_index))]
#记录下当前是按什么排序字段的
current_ordered_column[orderby_key] = orderby_index
if orderby_index.startswith('-'):
orderby_key = '-' + orderby_key return querysets.order_by(orderby_key),current_ordered_column
else:
return querysets,current_ordered_column

(3)table_obj_list.html
<th><a href="?_o={% get_sorted_column column sorted_column forloop.counter0 %}">{{ column }}</a></th>

(4)添加正序倒序的图标
Boorstrap组件:https://v3.bootcss.com/components/

把bootstrap的fonts静态文件放到kingadmin/staic/fonts下面

(5)kingadmin_tags.py
@register.simple_tag
def render_sorted_arrow(column,sorted_column):
'''排序的图标''' if column in sorted_column:
last_sort_index = sorted_column[column]
if last_sort_index.startswith('-'):
arrow_direction = 'bottom' else:
arrow_direction = 'top'
ele = '''<span class="glyphicon glyphicon-triangle-%s" aria-hidden="true"></span>'''% arrow_direction
return mark_safe(ele) return ''
(6)table_obj_list.html
<th><a href="?_o={% get_sorted_column column sorted_column forloop.counter0 %}">
{{ column }}{% render_sorted_arrow column sorted_column %}
</a></th>

效果:

6.2.分页、排序和过滤组合使用
(1)排序和过滤组合
table_obj_list.html

(2)kingamdin_tags.py
@register.simple_tag
def render_filtered_args(admin_class):
'''拼接过滤的字段'''
if admin_class.filter_conditions:
ele = ''
for k,v in admin_class.filter_conditions.items():
ele += '&%s=%s'%(k,v)
return mark_safe(ele)
else:
return ''
现在过滤和排序的组合没有问题,但是分页还没有组合到一起
(3)过滤和分页组合
table_obj_list.html

kingadmin_tags.py

def render_paginator先添加一个参数admin_class

(4)分页、排序、过滤组合
table_obj_list.py

kingadmin_tag.py
@register.simple_tag
def get_current_sorted_column_index(sorted_column):
#三元运算,如果为True执行左边的,为False,执行右边的('')
return list(sorted_column.values())[0] if sorted_column else ''
table_obj_list.py

kingadmin_tag.py

现在排序、过滤和分页组合就没有问题了

6.3.搜索功能开发
全局搜索
(1)table_obj_list.html

(2)kingadmin/views.py

from django.db.models import Q def get_searched_result(request,querysets,admin_class):
'''搜索''' search_key = request.GET.get('_q')
if search_key:
q = Q()
q.connector = 'OR' for search_field in admin_class.search_fields:
q.children.append(("%s__contains"%search_field,search_key)) return querysets.filter(q)
return querysets

现在实现的是全局搜索功能(不能过滤的同时搜索), 下面添加 过滤+搜索的功能
过滤+搜索
只需要添加一个隐藏标签就可以
kingadmin/vies.py

table_obj_list.html

效果:

功能优化
(1)用户并不知道可以通过哪些字段去搜索,在搜索框里添加提示(placeholder)

<form action="">
<input type="search" placeholder="{% for s in admin_class.search_fields %}{{ s }},{% endfor %}" name="_q" value="{{ admin_class.search_key }}">
<input type="submit" value="Search">
{% for k,v in admin_class.filter_conditions.items %}
<input type="hidden" name="{{ k }}" value="{{ v }}">
{% endfor %}
</form>
(2)添加Bootstrap样式
过滤字段提示和美化
table_obj_list.html
“过滤”按钮

kingadmin_tags.py
过滤字段提示+添加框的美化样式

末尾要加</div>闭合

显示效果:

CRM客户关系管理系统(六)的更多相关文章
- Django CRM客户关系管理系统
CRM需求分析 随着信息化时代带来的科技创新,CRM客户关系管理系统带来的效益在已经成为很多企业提高竞争优势的一分部,CRM客户关系管理系统将企业管理和客户关系管理集成到统一的平台,其系统功能主要体现 ...
- CRM 客户关系管理系统
CRM(Customer Relationship Manager)客户关系管理系统 企业为提高核心竞争力,利用相应的信息技术以及互联网技术协调企业与顾客间在销售.营销和服务上的交互,从而提升其管理方 ...
- CRM客户关系管理系统 北京易信软科信息技术有限公司
北京易信软科信息技术有限公司 推出大型erp系统,库存管理系统,客户关系管理系统,车辆登记管理系统,员工管理系统,采购管理系统,销售管理系统,为您的企业提供最优质的产品服务 北京易信软科您可信赖的北京 ...
- CRM客户关系管理系统-需求概设和详设
大概设计 大概设计就是对需求进行一个整体性分析,把需要实现的功能都列出来,对于客户关系管理系统,我们需要从角色出发,从而确定有哪些需求,最好是画个思维导图 首先我们是为培训学校这么一个场景来开发的,所 ...
- Django项目:CRM(客户关系管理系统)--70--60PerfectCRM实现CRM学生上课记录
#urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...
- Django项目:CRM(客户关系管理系统)--58--48PerfectCRM实现CRM客户报名流程学生合同
# sales_urls.py # ————————47PerfectCRM实现CRM客户报名流程———————— from django.conf.urls import url from bpm. ...
- CRM客户关系管理系统有哪些优缺点?
CRM系统不仅仅是一种技术,也是面向企业的客户管理系统.客户关系管理软件可以帮助销售员快速地找到客户信息,帮助销售员跟踪客户直到完成订单.为提高企业销售效率,CRM被越来越多的企业所采用. 那么,作为 ...
- CRM客户关系管理系统(一)
第一章.CRM介绍和开发流程 1.1.CRM简介 客户关系管理(CRM) 客户关系管理(customer relationship management)的定义是:企业为提高核心竞争力,利用相应的信息 ...
- Django项目:CRM(客户关系管理系统)--84--74PerfectCRM实现CRM权限和权限组限制访问URL
#models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...
- Django项目:CRM(客户关系管理系统)--85--75PerfectCRM实现CRM扩展权限
# sales_urls.py # ————————47PerfectCRM实现CRM客户报名流程———————— from django.conf.urls import url from bpm. ...
随机推荐
- 基于UDP协议的控制台聊天程序(c++版)
本博客由Rcchio原创,转载请告知作者 ------------------------------------------------------------------------------- ...
- 卷积神经网络的一些经典网络(Lenet,AlexNet,VGG16,ResNet)
LeNet – 5网络 网络结构为: 输入图像是:32x32x1的灰度图像 卷积核:5x5,stride=1 得到Conv1:28x28x6 池化层:2x2,stride=2 (池化之后再经过激活函数 ...
- 微信小程序开发-IP地址查询-例子
微信小程序开发 小程序搜索框 IP地址查询 搜索查询 样例 微信小程序 开发 参考 https://mp.weixin.qq.com/debug/wxadoc/dev/component/ ...
- asp.net core 二 Nginx Supervisor 负载,监听
ASP.NET Core负载均衡集群搭建(CentOS7+Nginx+Supervisor+Kestrel) asp.net core在linux运行下,一但命令行退出 ...
- ubuntu 添加右键打开方式,无法添加程序打开方式
最近把工作环境迁移到ubuntu,装了WPS for Linux ,说实话确实是十分良心啊!运行效率奇高,绿色无广告,并且和windows版本无异,感觉就可以抛弃自带的libreoffice了. 但是 ...
- winform中的数据绑定
1. 简单的数据绑定 例1 using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings[& ...
- [LeetCode] Count Different Palindromic Subsequences 计数不同的回文子序列的个数
Given a string S, find the number of different non-empty palindromic subsequences in S, and return t ...
- 智能合约开发solidity编程语言开发一个以太坊应用区块链投票实例
智能合约开发用solidity编程语言部署在以太坊这个区块链平台,本文提供一个官方实战示例快速入门,用例子深入浅出智能合约开发,体会以太坊构建去中心化可信交易技术魅力.智能合约其实是"执行合 ...
- python-文件操作和集合
1.打开文件 如果文件不存在会报错 f = open('information.txt','r+') 2.读取文件 read 读取文件 readline 读取文件的一行内容 readlines 读取文 ...
- Mysql 基于GTID的主从复制(实操)
实现环境: Master 主:192.168.0.102 (Mysql 5.6.36) Slave 从 :192.168.0.103 (Mysql 5.6.36) 步骤1.在主DB服务器上建立复制账 ...