1. 程式人生 > >組件添加模糊搜索功能

組件添加模糊搜索功能

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 %} <!-- 定制模糊搜索 結束 --> 技術分享

2.後端取出來作為組拼搜索條件 @property def search_condition(self):
"""獲取模糊搜索條件""" 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

組件添加模糊搜索功能