上一篇,我只是做了。 默认的显示。

    def __iter__(self):
'''默认显示。 用户可以自定制'''
if isinstance(self.queryset_or_tuple, list):
for item in self.queryset_or_tuple:
yield "<a href='#'>%s</a>" % item[1]
else:
for item in self.queryset_or_tuple:
if isinstance(item, Model):
print(item)
yield "<a href='#'>%s</a>" % item

能看出的是, 我返回的这个  yield  只是需要一个, 文本的信息。  而且是在这里做了判断,类型。
改进一下, 既然我只需要一个文本信息。 那么 这个工作, 应该交给 使用者,自己进行指定。
比如  默认返回   <a href='#'>男</a>   我想加点东西,比如  <a href='#'>男666</a>

而且,并不是所有的都加。  如果我直接在  __iter__ 中。 给他加666。 也是可以的, 只需要在 search_group 列表。 加入对象的时候。为对象, 添加一个参数就可以了。

但是我想换一种方式, 这个参数还是需要制定的, 但是获取文本的这个工作。 我交给   Option 类来做。 在类中添加一个参数。用于在最初的类型判断时, 就指定出,当前的 这个 field 对象。  是一个 choice 还是一个  Model 对象。

class Option(object):
'''使用组合搜索, 想要一些自己的搜索条件。 可扩展可继承'''
def __init__(self, field, db_condition=None, text_func=None):
'''
:param filed: 组合搜索关联的字段
:param db_condition: 数据库关联查询时查询的条件
:param text_func: 此函数用于,页面组合搜索的文本和样式
'''
self.field = field
self.db_condition = db_condition
self.text_func = text_func
if not db_condition:
db_condition = {}
self.db_condition = db_condition self.is_choice = False # 用于判断field对象里面是一个 choice列表 or 外键的queryset
  # 添加的函数就是这个,
def get_text_func(self, field_obj):
'''
获取文本,的函数。(从)
:param field_obj: (1, "男") or model对象
:return:
'''
if self.text_func: # 这个参数就是让用户来自己制定的。 下面展示如何使用。
return self.text_func(field_obj)
    # 通过 is_choice 判断是否是 choice。 决定返回的是,元组中的 第二个元素。 还是关联表的表名(verbose_name="部门")
if self.is_choice:
return field_obj[1]
return str(field_obj) def get_db_condition(self, request, *args, **kwargs):
'''预留继承后的重写函数, 重写后,次基类中的该方法,将被覆盖。 默认返回的是开发者输入的值。'''
'''重写后, 可根据,前端的返回值,进行一定的判断'''
return self.db_condition def get_queryset_or_tuple(self, model_class, request, *args, **kwargs):
'''根据字段去获取数据库关联的数据''' # 根据gender或者classes字符串,组自己对应的model类中,找到字段对象,再根据对象,获取关联的数据
field_obj = model_class._meta.get_field(self.field) # 固定用法mate 类,中的get_field() 就可以根据字符串获取对应的对象
# 对field_obj 的类型做判断。 来确定他是一个 choice 还是一个 foreignkey 外键
if isinstance(field_obj, ForeignKey) or isinstance(field_obj, ManyToManyField):
# 获取关联表中的, 数据 django1.0 版本使用 field_obj.rel.model.objects.all()
db_condition = self.get_db_condition(request, *args, **kwargs)
return SearchGroupRow(field_obj.related_model.objects.filter(**db_condition), self)
# 这里得到的是 Queryset 类型
else:
# 获取 choice 的数据 field_obj.choices
self.is_choice = True
return SearchGroupRow(field_obj.choices, self) # 这里得到的是 tuple 类型

在  UserInfoHandler 这个类中, 为search_group 添加 对象的时候。 可以选择性的为, Option类,添加一个函数进去。  如果添加了那么就会执行,传入的这个函数。 页面进行显示的时候, 就能够根据,用户自己的函数,逻辑进行展示。

class UserInfoHandler(StartHandler):
    ...................# 配置组合搜索,想要展示哪些, 搜索的条件
search_group =   [
Option("gender",text_func=lambda field_obj:field_obj[1]+""),
Option("classes"),
MyOption("depart",text_func=lambda x:x.title + "123"),
]

最后就是,原来的  __iter__ 改成啥样了呢?

class SearchGroupRow(object):
def __init__(self, queryset_or_tuple, option):
self.option = option
self.queryset_or_tuple = queryset_or_tuple def __iter__(self):
'''默认显示。 用户可以自定制'''
for item in self.queryset_or_tuple:
text = self.option.get_text_func(item)
yield "<a href='#'>%s</a>" % text

变简单了!不再进行判断类型。 因为这个工作,前面已经做了。  这里就只是执行了一下 传进来 option 对象下的  get_text_func()这个函数。 并且将当前循环的  field 对象。 传给了他。
最后看一下页面效果:

能看出,  gender  我进行了自定制。 后面加了 666
derpart  进行了自定制。 后面加了 123
classes  没有自定制, 默认显示的就是。 模型表中  __str__ 返回的值。

 最后一点,就是标题了。 在每个前面,添加上一个标题。 这样就知道,我选择的是什么选项了:

改动也不是很大。 就是通过  verbose_name  获取。 field 对象。 中的  verbose_name 设置的文字。

然后 传给SearchGruop 类。 实例化的时候, 对象就拥有这个参数。
然后  __iter__ 函数中,返回一个这个值就可以了。

class SearchGroupRow(object):
def __init__(self, queryset_or_list, option, title):
self.title = title
self.option = option
self.queryset_or_list = queryset_or_list def __iter__(self):
for item in self.queryset_or_list:
yield self.title
yield "<a>全部</a>"
text = self.option.get_text_func(item)
yield "<a href='#'>%s</a>" % text
class Option(object):
'''使用组合搜索, 想要一些自己的搜索条件。 可扩展可继承'''
def __init__(self, field, db_condition=None, text_func=None):
self.field = field
self.db_condition = db_condition
self.text_func = text_func
if not db_condition:
db_condition = {}
self.db_condition = db_condition self.is_choice = False # 用于判断field对象里面是一个 choice列表 or 外键的queryset
  ........................
def get_queryset_or_list(self, model_class, request, *args, **kwargs):
'''根据字段去获取数据库关联的数据''' # 根据gender或者classes字符串,组自己对应的model类中,找到字段对象,再根据对象,获取关联的数据
field_obj = model_class._meta.get_field(self.field) # 固定用法mate 类,中的get_field() 就可以根据字符串获取对应的对象
title = field_obj.verbose_name # 获取到,文件的 verbose_name
# 对field_obj 的类型做判断。 来确定他是一个 choice 还是一个 foreignkey 外键
if isinstance(field_obj, ForeignKey) or isinstance(field_obj, ManyToManyField):
# 获取关联表中的, 数据 django1.0 版本使用 field_obj.rel.model.objects.all()
db_condition = self.get_db_condition(request, *args, **kwargs)
return SearchGroupRow(field_obj.related_model.objects.filter(**db_condition), self, title) # 传进来
# 这里得到的是 Queryset 类型
else:
# 获取 choice 的数据 field_obj.choices
self.is_choice = True
return SearchGroupRow(field_obj.choices, self, title) # 这里得到的是 tuple 类型

stark组件开发之组合搜索高级显示和扩展的更多相关文章

  1. stark组件开发之组合搜索基本显示

    数据的获取,上一篇,已经有了!然后就是,如何进行展示的问题.到了展示这里,又有了新的问题, 因为从数据库,取得的数据. 分为 queryset 和 tuple 两种数据结构.tuple 中,只是字符串 ...

  2. stark组件开发之组合搜索页面效果和 URL

    页面效果,只是样式.这个好解决!yield 的时候. 返回几个样式出去就好了! 并且前端写上一些样式的css {% if search_group_row_list %} <div class= ...

  3. stark组件开发之组合搜索实现思路

    - 关键字搜索. 可以做到的效果是, 输入20. 后太通过 Q()  函数. 来实现.  搜索是一个大的问题点. -  要想实现组合搜索, 首先要 明确的一点是. 在我当前的页面上, 正在进行展示的是 ...

  4. stark组件开发之关键搜索

    - 模糊搜索: 在页面生成一个表单.  以get 方式, 将数据提交到.当前查看页面. 后台接收数据,然后进行筛选过滤. 着个也需要,用户自定制!   定义一个  search_list  这个值,默 ...

  5. stark组件开发之列表页面定制列

    先看一张页面展示的效果图: 看一看我的  model 表!是什么样子: 看一看数据库是什么样子: 看 页面展示图,有表头. 有数据.模型表中,每一个字段, 都指定了 verbose_name. 如何解 ...

  6. stark组件开发之列表页面应用示例

    已经解决的,自定义的扩展函数,功能.但是 不可能返回. 一个 固定的页面把!  应该是,点击那条 记录之后的编辑, 就会跳转到相应的,编辑页面.所以 这个标签的  <a href="/ ...

  7. 轮播组件/瀑布流/组合搜索/KindEditor插件

    一.企业官网 ### 瀑布流 ​ Models.Student.objects.all() #获取所有学员信息 ​ 通过div进行循环图片和字幕 ​ 1.以template模板方法实现瀑布流以列为单位 ...

  8. stark组件开发之添加按钮显示和URL

    添加: 需求: 根据用户的权限, 决定是否,有添加按钮.  通过配置进行定制,预留钩子进行权限的判断. class StartHandler(object): .................... ...

  9. stark组件开发之列表页面预留钩子方法。 可根据用户的不同,显示不同的列

    要实现,这个方法.子类中 list_diplay 这个列表, 就不能够写死.他应该是 可以根据.用户的不同,返回不同的值. 所以 就需要一个函数, 可以进行判断当前用户是谁. 并且往这个列表中添加,他 ...

随机推荐

  1. JavaScript 正则表达式学习笔记

    定义规则让计算机去处理字符串正则表达式写法: //第一种 var reg = new RegExp('ab'); //第二种 var reg = /ab/; 量词:{} [a-z] 从小写a-z [A ...

  2. 163邮箱报错WARN: 535 Error: authentication failed.

    会让输入自定义授权码..用这个密码代替邮箱的密码,就可以发邮件了.

  3. 微信小程序之弹出操作菜单

    <view class="List_count" bindtap="actioncnt"> <view class="img&quo ...

  4. 关于如何使用ehcarts2加载svg矢量地图并自定义县级内部乡镇轮廓

    项目需求:显示县级内部的乡镇一级地图的轮廓! 效果预览: 阻碍因素:echarts不提供县级以下乡镇级轮廓. 解决思路: 1.根据资料查找相关县的行政区域图(百度搜索),如本人所制作的浙江省宁波市宁海 ...

  5. Python全栈开发记录_第五篇(装饰器)

    单独记录装饰器这个知识点是因为这个知识点是非常重要的,必须掌握的(代码大约150行). 了解装饰器之前要知道三个知识点 作用域,上一篇讲到过顺序是L->E->G->B 高阶函数: 满 ...

  6. C#通过COM组件调用IDL的pro程序

    如果在“COM_IDL_connectLib.COM_IDL_connect oComIDL = new COM_IDL_connectLib.COM_IDL_connect();”步骤提示“...8 ...

  7. nginx配置多个域名

    1.原来的80端口改掉,下面配置: server { listen 80; server_name *.pobohn.com; location / { proxy_pass http://local ...

  8. Android中四大组件总结

    android四大组件分别为activity.service.content provider.broadcast receiver. 一.android四大组件详解 1.activity (1)一个 ...

  9. 新装 Win7 系统装完驱动精灵,一打开到检测界面就卡死——原因与解决方案

    1.现象: 重装系统后,鼠标反应慢,且不能上网.因此装了个驱动精灵,准备更新下驱动,但驱动精灵一打开到检测界面就卡死(换驱动人生.鲁大师也一样). 2.原因: Win7 系统 iso 中自带的驱动程序 ...

  10. c#_生成图片式验证码

    废话不多说直接上代码. class Check_Code { /// <summary> /// 生成随机验证码数字+字母 /// </summary> /// <par ...