組件添加模糊搜索功能
阿新 • • 發佈:2017-10-28
spl rgba icon extend ret control 搜索功能 attr 輸入 1.前端發送搜索請求,
<!-- 定制模糊搜索 開始 -->
{% if cl.search_list %}
<div class="row">
<form action="">
<input type="text" name="{{ cl.search_attr.name }}" value="{{ cl.search_attr.value }}" class="form-control"
style="display: inline-block;width: 250px" placeholder="請輸入關鍵字">
<button type="submit" class="btn btn-primary">
<span class="glyphicon glyphicon-search"></span>
</button>
</form>
</div>
{% endif %}
<!-- 定制模糊搜索 結束 -->
"""獲取模糊搜索條件"""
con = Q()
con.connector = "OR"
val = self.request.GET.get(self.q)
if not val:
return con
for k in self.get_search_list():
k="%s__contains"%k
con.children.append((k,val))
return con
data_list = self.model_class.objects.filter(**self.filter_condition).filter(self.search_condition ).distinct()
3.支持可配置式,子類裏面復寫並傳值才顯示搜索框
search_list=[]
def get_search_list(self):
"""獲取搜索的列,即將會在數據庫的哪些列中搜索這些信息"""
search_list = []
search_list.extend(self.search_list)
return search_list
2.後端取出來作為組拼搜索條件 @property def search_condition(self):
組件添加模糊搜索功能