思路
服务v1.py模块导入
from django.db.models import Q
新增函数筛选功能
search_list = []
def get_search_list(self):
return self.search_list
changelist_view函数新增筛选功能逻辑
search_list = self.get_search_list()
search_value = request.GET.get('q', '')
conn = Q()
conn.connector = 'OR'
if search_value:
for item in search_list:
conn.children.append((item, search_value))
修改排序sql
queryset = self.model_class.objects.filter(conn).order_by(*order_list)
stark组件中各个功能可以定制默认筛选项,使用方法
# 姓名中含有关键字或邮箱中含有关键字
search_list = ['name__contains', 'email__contains']
前端模板需要增加筛选功能
{% if search_list %}
<div style="float: right;">
<form method="GET" class="form-inline">
<div class="form-group">
<input class="form-control" type="text" name="q" value="{{ search_value }}" placeholder="关键字搜索">
<button class="btn btn-primary" type="submit">
<i class="fa fa-search" aria-hidden="true"></i>
</button>
</div>
</form>
</div>
{% endif %}
效果展示