stark组件开发之关键搜索
- 模糊搜索:
在页面生成一个表单。 以get 方式, 将数据提交到。当前查看页面。 后台接收数据,然后进行筛选过滤。
着个也需要,用户自定制!
定义一个 search_list 这个值,默认为空。 页面进行判断,为空就不显示。 搜索框!
如果,用户 定义了这个列表, 那么就显示!
class StartHandler(object):
..........
search_list = [] # 方便,用户自己定制。关键字搜索的条件,和如果用户不配置,页面不显示搜索框
def get_search_list(self):
return self.search_list # ##################3. 获取排序,和, 模糊搜索的条件######################
from django.db.models import Q, F # 用于构造复杂的 搜索条件
order_list = self.get_ordered_list() # 排序方式 默认 使用 id 进行正向排序
search_list = self.get_search_list() # 搜索的条件 ["name_contains", "email"]
'''
1. 如果 search_list 为空, 则不显示 搜索框
2. 获取用户输入的 关键字
3. 构造搜索条件
'''
search_value = self.request.GET.get("q", "") # 获取用户发送过来的关键字,如果没有 q 这个参数。 就返回 None
conn = Q()
conn.connector = "OR" # 让添加进来的条件, 做 or 判断
if search_value: # 接收到了用户的搜索,才进行模糊查询。 否则啥都不干
for item in search_list:
conn.children.append((item, search_value))
............ return render(request, "stark/changelist.html",
{"header_list": header_list, "data_list": data_list,
"body_list": body_list,
"pager": pager,
"add_btn": add_btn,
"search_list": search_list,
"search_value": search_value,
"action_dict": action_dict})
子类中, 由用户自己定制:
class UserInfoHandler(StartHandler):
......
search_list = ["name_contains"] # 如果这里不设置的话, 就不显示搜索框
def get_search_list(self):
'''重写该方法,可以进行对用户 权限的判断。 从而决定该用户是否, 有搜索的权限'''
接下来就是一个 ,模糊搜索了: 先看一了 例子!:
from django.db.models import Q, F # 用于构造复杂的 搜索条件
conn = Q()
conn.connector = "OR" # 让添加进来的条件, 做 or 判断
conn.children.append(("name__contains", "lijie"))
conn.children.append(("email", "lijie"))
conn.children.append(("id__gt", 5))
self.model_class.objects.filter(conn) # 这样就可以根据添加进 Q 的条件, 按照 or 的方式。在数据库查询!
ORM 无法进行,复杂的搜索条件。 所以使用 django 内置的 Q 方法来做这件事!
所以重点还是 子类中需要自定制的 search_list = ["name_contains"] 这里才是决定了。 前端更够查询到的东西。
但是,这里还是, 定死了的。 如果想要更加的灵活。 以后再说:
先看看。 整体代码吧!
stark组件开发之关键搜索的更多相关文章
- stark组件开发之组合搜索页面效果和 URL
页面效果,只是样式.这个好解决!yield 的时候. 返回几个样式出去就好了! 并且前端写上一些样式的css {% if search_group_row_list %} <div class= ...
- stark组件开发之组合搜索实现思路
- 关键字搜索. 可以做到的效果是, 输入20. 后太通过 Q() 函数. 来实现. 搜索是一个大的问题点. - 要想实现组合搜索, 首先要 明确的一点是. 在我当前的页面上, 正在进行展示的是 ...
- stark组件开发之组合搜索高级显示和扩展
上一篇,我只是做了. 默认的显示. def __iter__(self): '''默认显示. 用户可以自定制''' if isinstance(self.queryset_or_tuple, list ...
- stark组件开发之组合搜索基本显示
数据的获取,上一篇,已经有了!然后就是,如何进行展示的问题.到了展示这里,又有了新的问题, 因为从数据库,取得的数据. 分为 queryset 和 tuple 两种数据结构.tuple 中,只是字符串 ...
- stark组件开发之列表页面定制列
先看一张页面展示的效果图: 看一看我的 model 表!是什么样子: 看一看数据库是什么样子: 看 页面展示图,有表头. 有数据.模型表中,每一个字段, 都指定了 verbose_name. 如何解 ...
- stark组件开发之列表页面应用示例
已经解决的,自定义的扩展函数,功能.但是 不可能返回. 一个 固定的页面把! 应该是,点击那条 记录之后的编辑, 就会跳转到相应的,编辑页面.所以 这个标签的 <a href="/ ...
- stark组件开发之添加功能实现
添加功能,还是使用, form 组件来完成! 并且 完成添加之后,需要保留原搜索条件. def memory_url(self): '''用于反向生成url, 并且携带,get请求的参数,跳转到下一 ...
- stark组件开发之编辑功能实现
编辑功能.和添加一样! 唯一不同的就是, 需要编辑一个指定的 记录.这就需要,在列表页面, 渲染编辑的时候,添加一个 id 值: class UserInfoHandler(StartHandler ...
- stark组件开发之添加按钮显示和URL
添加: 需求: 根据用户的权限, 决定是否,有添加按钮. 通过配置进行定制,预留钩子进行权限的判断. class StartHandler(object): .................... ...
随机推荐
- 子数组的最大异或和---Trie
异或的运算法则为:0⊕0=0,1⊕0=1,0⊕1=1,1⊕1=0(同为0,异为1),这些法则与加法是相同的,只是不带进位,所以异或常被认作不进位加法. 前缀树详解:https://www.cnblog ...
- bootstrap modal 点击头部移动
$(".modal").each(function(){ $(this).draggable({ handle: ".modal-header" // 只能点击 ...
- [转]golang的goroutine调度机制
golang的goroutine调度机制 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 一直对goroutine的调度机制很好奇最近在看雨痕的golang源码分析基于go ...
- Jquery 样式选择器,查找包含两种样式以上的元素
可以连写 $(".样式一.样式二") 中间不要留空格,id也一样. $(".modalDishMsgTitleWrap").find(".standa ...
- 【java】设计模式-单例设计模式
单例设计模式:解决一个类在内存中是存在一个对象的问题.当需要该事物的对象在内存中唯一时,将以下三步添加即可. 思想:想要保证对象唯一1.为了避免其他程序过多的建立该类对象,先禁止其他程序建立该类对象2 ...
- verilog 代码分析与仿真
verilog 代码分析与仿真 注意:使用vivado 自带的仿真工具, reg和wire等信号需要赋予初始值 边沿检测 module signal_test( input wire cmos_pcl ...
- Python3 字典 setdefault() 方法
Python 字典 setdefault() 函数和get() 方法类似, 如果键不存在于字典中,将会添加键并将值设为默认值. dict.setdefault(key, default=None) k ...
- CSS之padding&margin
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- CentOS7 JDK1.8部署详解
一.下载 首先需要将本地下载好的jdk包拷贝到Linux中:scp jdk-8u91-linux-x64.tar.gz hadoop@192.168.***.***:~/software/ //星号处 ...
- python3 列表去除重复项保留原序
l1 = ['a',1,'c','b',2,'b','c','d','a'] l2= sorted(set(l1),key=l1.index) print('l2:',l2) print('l1:', ...