中国的思维跟老外还是不大一样,很多后台在列表页面都有控制按钮,现在很多人都习惯这种操作方式。举个例子,看图:
image.png其实增删改在django后台都可以实现,通过勾选+操作选项的形式。有的客户就要上图这种形式,那也不能不做呀。
再有一种情况,比如我们做OA系统的时候,经常有“审核”等功能,在某条记录后面加“审核”按钮似乎也是合理的。研究了一下Django是如何在列表页面添加按钮。
思路:
首先,我想到的是修改前端模板,即:change_list.html 模板,把它从Django框架里复制处理,放到项目目录下project/templates/admin/change_list.html。放到这里就可以覆盖系统自带的前端模板了,如果你有多个APP,那在templates下面要先加app名称。否则一换所有的app都换了。
在chanle_list.html页面中发现如下代码:
{% block result_list %}
{% if action_form and actions_on_top and cl.show_admin_actions %}{% admin_actions %}{% endif %}
{% result_list cl %}
{% if action_form and actions_on_bottom and cl.show_admin_actions %}{% admin_actions %}{% endif %}
{% endblock %}
就是这个 {% result_list cl%} 这个tage 返回的是数据列表,于是乎,又去看 admin_list.py 里关于这个tage的写法,重写这个方法应该可以实现。
在研究tages和过滤器的写法的时候,发现这种方法应该是可行的,但是有必要吗?
于是乎,又google了一下,用英文的方式搜索,额,答案找到了:在 admin.py里,用list_display方法来实现。
先简后难,先试试吧。
首先,要定义一个方法,返回html,button标准。list_display=(1,2,3,自定义的方法)
按这个思路试了一下:
def buttons(self, obj):
button_html = """<a class="changelink" href="#">编辑</a>"""
return format_html(button_html)
buttons.short_description = "操作"
list_display = ('ID', 'device_name', 'UID', 'View_ID', 'U_key', 'SN', 'create_time', 'buttons')
看看后台页面,还真的出来了。
image.png
下面就是给button添加功能连接了。
很简单,我们点击菜单中首列就能打开编辑页面,那我们看看打开编辑页面的地址吧。
通过浏览器地址栏,我们看看编辑页面的地址为:http://127.0.0.1:8000/admin/devicemanager/devices/2/change/
那个2肯定是变量了,其他都是固定不变的。
那就要从上下文中获取到列表参数了,就是取ID值。(不同的model的设计,取得东西也不一样,结合自己得自身情况来)。
最终修改:
def buttons(self, obj):
button_html = """<a class="changelink" href="/admin/devicemanager/devices/%s/change/">编辑</a>""" % (
obj.ID)
return format_html(button_html)
buttons.short_description = "操作"
list_display = ('ID', 'device_name', 'UID', 'View_ID', 'U_key', 'SN', 'create_time', 'buttons')
打开列表,点击编辑试试?
成功~~!
网友评论