class UserInfoHandler(StartHandler):
  .......
# 批量操作功能的列表,添加则显示, 使用此功能。需要将StartHandler.display_checkbox 添加到list_display 中
action_list = [StartHandler.action_multi_delete, StartHandler.action_multi_init]
  .......
class StartHandler(object):
  ........
def action_multi_delete(self, request, *args, **kwargs):
'''批量删除( 如果想要定制,执行成功后的返回值,那么就为这个函数,设置返回值就可以)'''
self.model_class.objects.filter(pk__in=request.POST.getlist("pk")).delete()
# return redirect("http://www.baidu.com")
action_multi_delete.text = "批量删除" # 用户自定制,是否使用该功能。 只要在子类中的 action_list=[StarkHandler.multi_init] 就可以使用该功能
def action_multi_init(self, request, *args, **kwargs):
'''批量初始化'''
pass
action_multi_init.text = "批量初始化"
# 如果像模板中,传递一个函数的话,他就会自动的执行一边。 从而前端的页面也因为这个原因,拿不到 text 的值。
# 所以就需要在后端把这个 action_list 处理成一个字典。这件事由基类完成 {func.__name__: func.text for func in action_list} def get_list_display(self):
........ # ####################1. 处理 Action ######################
action_list = self.get_action_list()
action_dict = {func.__name__: func.text for func in action_list} # func.__name__获取函数名, func.text获取函数文本
if request.method == "POST":
action_func_name = request.POST.get("action")
if action_func_name and action_func_name in action_dict: # 前端发送过来的name 必须要在 action_dict中。
action_respons = getattr(self, action_func_name)(request, *args, **kwargs)
if action_respons:
return action_respons
.........       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}) action_list = []
def get_action_list(self):
return self.action_list

D:\prev_new_stark\stark\servers\start_v1.py

标红位置的, 部分就是。 处理此批量操作的。 功能:

{% extends "layout.html" %}
{% block content %}
.......<form action="" method="post">
{% csrf_token %}
{% if action_dict %}
<div style="float: left; margin: 0 10px 5px 0">
<div class="form-inline">
<div class="form-group">
<select name="action" id="" class="form-control">
<option value="">请选择操作</option>
{% for func_name, func_text in action_dict.items %}
<option value="{{ func_name }}">{{ func_text }}</option>
{% endfor %}
</select>
<input type="submit" name="" value="执行" class="btn-success btn">
</div>
</div>
</div>
{% endif %}
{% if add_btn %}
<div style="float: left">{{ add_btn|safe }}</div>
{% endif %} <table class="table table-bordered">
<thead>
<tr>
{% for head in header_list %}
<th>{{ head }}</th>
{% endfor %}
</tr>
</thead>
<tbody>
{% for row in body_list %}
<tr>
{% for ele in row %}
<td>{{ ele }}</td>
{% endfor %}
</tr>
{% endfor %}
</tbody>
</table>
</form>
</div>
......
{% endblock %}

此部分, 使用的知识点:

# 如果向模板中,传递一个函数的话,他就会自动的执行一边。 从而前端的页面也因为这个原因,拿不到 text 的值。
# 所以就需要在后端把这个 action_list 处理成一个字典。这件事由基类完成 {func.__name__: func.text for func in action_list}

{func.__name__: func.text for func in action_list}
简单的字典生成式。
action_list 中循环出,每一个函数对象。  func.__name__ 获取这个函数的函数名。 func.text 获取这个函数的文本信息!
前端中:

{% for func_name, func_text in action_dict.items %}
<option value="{{ func_name }}">{{ func_text }}</option>
{% endfor %}
使用  items 方法。  获取到, 字典中的  key 和 value。  也就是函数名, 和函数文本。

POST 提交时,将 函数名,提交给后台。 后台通过反射的 方式。 找到这个 函数。 并执行。

并且 该函数, 也可以有返回值。 自定制批量操作成功,之后 可以跳转到,那个页面。

stark组件开发之批量操作的更多相关文章

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

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

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

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

  3. stark组件开发之添加功能实现

    添加功能,还是使用, form 组件来完成!  并且 完成添加之后,需要保留原搜索条件. def memory_url(self): '''用于反向生成url, 并且携带,get请求的参数,跳转到下一 ...

  4. stark组件开发之分页

    """ 分页组件 """ class Pagination(object): def __init__(self, current_page ...

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

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

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

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

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

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

  8. stark组件开发之排序

    class StartHandler(object): .......... ordered_list = [] # 排序规则由 用户指定. def get_ordered_list(self): r ...

  9. stark组件开发之编辑功能实现

    编辑功能.和添加一样! 唯一不同的就是, 需要编辑一个指定的  记录.这就需要,在列表页面, 渲染编辑的时候,添加一个 id 值: class UserInfoHandler(StartHandler ...

随机推荐

  1. Python的深copy和浅copy

    浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象. 深拷贝(deepcopy): copy 模块的 deepcopy 方法,完全拷贝了父对象及其子对象. 浅copy: a = [1, 2, ...

  2. openstry lua redis实现负载均衡

    需求: 通过URI地址http://10.0.0.148/test2?uuid=123的uuid参数值的第一位,去实现redis的负载均衡 若uuid第一位为1,那么去10.0.0.148的redis ...

  3. .gitlab-ci.yml 配置文件,知识点

    官方介绍:https://docs.gitlab.com/ee/ci/yaml/README.html 翻译: https://segmentfault.com/a/1190000010442764

  4. 1.1.17 Word在表格中插入竖排文字,显示一半

    隐藏效果如下所示: 这是因为文字的[段落行距]设置为[固定值],将文字选中,设置为[单倍行距]即可.

  5. Zookeeper 集群搭建--单机伪分布式集群

    一. zk集群,主从节点,心跳机制(选举模式) 二.Zookeeper集群搭建注意点 1.配置数据文件 myid 1/2/3 对应 server.1/2/3 2.通过./zkCli.sh -serve ...

  6. axiso实战问题

    this.axios({ method: 'get', url: '/api/projectmgt/project/Project/list', withCredentials : true, hea ...

  7. Azure VMSS (2) 对VM执行Generalize操作

    <Windows Azure Platform 系列文章目录> 在本章中,笔者将介绍如何创建Azure Template镜像模板. 1.首先,我们先创建1台Windows Server 2 ...

  8. DevExpress破解和消除弹出框问题

    在解决方案管理器列表中找到 license.licx 设置属性 将[生成操作]选项改为[无]

  9. verilog 除法器

    verilog 除法器:利用二进制的除法翻译过来的硬件电路 1.1 实现算法 基于减法的除法器的算法: 对于32的无符号除法,被除数a除以除数b,他们的商和余数一定不会超过32位.首先将a转换成高32 ...

  10. 单源最短路径算法——Dijkstra算法(迪杰斯特拉算法)

    一 综述 Dijkstra算法(迪杰斯特拉算法)主要是用于求解有向图中单源最短路径问题.其本质是基于贪心策略的(具体见下文).其基本原理如下: (1)初始化:集合vertex_set初始为{sourc ...