Django 实现了自己的模板页面,并在 admin site 应用模块中添加了自己的跳转链接
Django admin site 与 ORM 结合,提供非常强大的数据库操作功能,少量代码即可快速显示数据库表数据、修改和修改保存的可视化页面和功能。
Django 管理页面的默认视图分为几个应用程序模块。每个应用程序模块下定义的数据库模型显示为作为超链接的表名称。例如,Django服务初始化时,默认只有一个Auth模块。下面有两个表:用户和组。添加Feedback用户自定义模块和Feedback表模型后,管理页面将如下所示:
有时我们需要为FEEDBACK应用程序定义一些自定义 该页面提供了站点+ORM管理的一些功能无法直接提供,例如根据反馈表中的条目汇总并显示每天不同类型反馈的总处理情况,然后在管理页面的相应应用模块下添加跳转链接。下面分两步记录实现步骤。
1。自定义Django模板页面
使用Django模板语言编写一个简单的feedback_stats.html文件。该文件必须位于 Django 加载 html 文件的默认路径下。在这里,选择其位于反馈/模板/下的位置。以下html文件根据传入的参数theheads和trows生成数据视图表:
{% extends "admin/base_site.html" %} {% load static %} {% block content %} <div> <label><h2>反馈统计</h2> </label> </br> <table class="table" table-layout="fixed" width="600px"> <thead> <tr> {% for thead in theads %} <th> {{ thead }} </th> {% endfor %} </tr> </thead> <tbody> {% for tr in trows %} <tr> {% for td in tr %} <td> {{ td | safe }} </td> {% endfor %} </tr> {% endfor %} </tbody> </table> </div> {% endblock %}
在views.py文件中,包含模板语法的html文件通过django.shortcuts.render渲染为纯html网页功能。并将计算出的数据记录作为键值参数传递给渲染函数。 Feedback/views.py文件内容如下:
#!/usr/bin/env python # coding=utf-8 from django.shortcuts import render import MySQLdb conn = MySQLdb.connect( host='localhost', port=3306, user='root', db='test' ) dtype = { 0: u'未知分类', 1: u'无法播放', 2: u'违规举报', 3: u'质量问题', } dstatus = { 0: u'待确认', 1: u'待解决', 2: u'已解决', 3: u'无需解决', } def feedback_stats(request): cursor = conn.cursor() cursor.execute('select defect_type, status, count(1) as cnt, left(ctime, 10) from feedback group by defect_type, status, left(ctime, 10) order by ctime desc;') records = [(dtype[x[0]], dstatus[x[1]], x[2], x[3]) for x in cursor.fetchall()] theads = ['反馈类型', '当前状态', '数量', '时间'] return render(request, 'feedback_stats.html', {"theads": theads, "trows": records})
feedback/urls.py文件内容如下:
#!/usr/bin/env python
# coding=utf-8 from django.conf.urls import url import views urlpatterns = [ url(r'^feedback_stats/$', views.feedback_stats), url(r'^admin/feedback_stats/$', views.feedback_stats), ]
存在以下数据数据库的反馈表中:
| id | video_id | udid | defect_type | message | ctime | total | status | +----+----------+----------+-------------+----------+---------------------+-------+--------+ | 1 | 1 | udid1234 | 3 | testtext | 2017-11-21 02:38:11 | 55 | 1 | | 2 | 1 | udid1234 | 3 | testtext | 2017-11-21 02:53:13 | 55 | 1 | | 3 | 1 | udid1234 | 0 | testtext | 2017-11-21 02:53:18 | 55 | 2 | | 4 | 1 | udid1234 | 0 | testtext | 2017-11-21 02:53:23 | 55 | 2 | | 5 | 11 | udid1234 | 0 | testtext | 2017-11-21 02:55:30 | 55 | 2 | | 6 | 19 | udid1234 | 0 | testtext | 2017-11-21 02:55:35 | 55 | 0 | | 7 | 19 | udid1234 | 0 | testtext | 2017-11-21 03:06:43 | 55 | 0 | | 8 | 19 | udid1234 | 0 | testtext | 2017-11-28 00:09:45 | 55 | 0 | | 9 | 11 | udid1234 | 0 | testtext | 2017-11-28 00:09:58 | 55 | 3 | | 10 | 101 | udid1234 | 1 | testtext | 2017-11-28 00:10:04 | 5 | 3 | | 11 | 121 | udid1234 | 1 | testtext | 2017-11-28 00:10:14 | 75 | 3 | | 12 | 77 | udid1234 | 1 | testtext | 2017-11-28 00:10:24 | 7 | 3 | | 13 | 27 | udid1234 | 2 | testtext | 2017-11-28 00:10:33 | 91 | 3 | | 14 | 27 | udid1234 | 2 | testtext | 2017-11-28 00:13:11 | 91 | 0 | | 15 | 32 | udid1234 | 2 | testtext | 2017-11-28 00:13:18 | 91 | 0 | +----+----------+----------+-------------+----------+---------------------+-------+--------+
请访问http://127.0.0.1:8000/feedback/feedback_stats/查看区分反馈类型的问题状态统计:
这里是模板的自定义功能统计页面已实现,可以通过路径/feedback/feedback_stats/或/admin/feedback/feedback_stats/访问。但是,该链接无法显示在管理页面上。 admin页面下FEEDBACK模块中,仍然只有一个跳转到feedback表admin页面的超链接,没有跳转到feedback_stats页面的超链接。子路径似乎是直接在 admin/feedback/ 路径之后手动添加的,而 Django 则不是。相应的跳转超链接不会自动智能添加到管理页面。如果每个自定义页面连接都无法在管理页面显示对应的超链接,并且每次使用时都手动输入完整路径非常麻烦,那么Django可以在管理页面添加用户自定义的超链接吗?定义页面的超链接怎么样?答案当然是肯定的。
提示:如果您想向管理页面添加自定义跳转链接,请首先考虑如何向相关应用添加新的跳转链接。我们以反馈模块为例。哪些情况会导致产生新的跳转连接?最常见的情况当然是添加映射到数据库的模型和相应的模型管理器。那么数据表模型对应的跳转链接可以重定向到我们自己的链接吗?这样,问题就转化为admin页面的modeladmin跳转链接是否可以重载的问题。这也是在page admin应用模块下添加自定义跳转链接的解决方案,所以默认跳转到modeladmin。重写行为指向自定义跳转页面,实现在app模块下添加自定义跳转链接的功能。
由于对应的数据表模型实际上只提供了在管理页面内生成跳转链接的功能,并没有实际访问它,所以不需要为其定义任何真实的字段并创建一个空的mock模型。是的,下面的代码对应的是models.py中的mock模型:
class Feedback_Stat(models.Model): pass
这是对应admin.py中的FeedbackStatsAdmin的代码。覆盖changelist_view modeladmin函数,该函数负责默认的页面渲染行为,实现自定义页面渲染:
from django.contrib import admin from django.shortcuts import render from models import Feedback, Feedback_Stat from views import feedback_stats @admin.register(Feedback_Stat) class FeedbackStatsAdmin(admin.ModelAdmin): def changelist_view(self, request, extra_content=None): return feedback_stats(request)
添加上述代码后,管理页面如下所示:
其中,Feedback_stats代表对应的链接反馈统计管理。点击后,由于重写了changelist_view方法,跳转到用户自定义的feedback_stats页面:
版权声明
本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。