django admin添加自己的页面

建立模型

如果要单独建一个页面,用于展示model的数据,可以新建一个model,继承自要展示的那个类

py 复制代码
class ViewsByDayModel(ViewsByDay): # 父类为要展示的model类
    class Meta:
        proxy = True # 使用代理
        verbose_name = '每日浏览次数统计'
        verbose_name_plural = verbose_name

代理模型 proxy = True 。允许为一个已存在的模型创建一个新的类,这个新类在数据库中没有与之对应的表,但它可以覆盖原始模型的行为,如改变默认的Manager、添加或覆盖方法、改变模型的Meta属性等。代理模型在Django的admin后台中特别有用,因为它允许你为同一个数据表提供不同的管理界面和行为。

admin中注册模型

py 复制代码
@admin.register(ViewsByDayModel)
class ViewsByDayAdmin(admin.ModelAdmin):
    change_list_template = 'admin/admin_log.html'
    
    def changelist_view(self, request, extra_context=None):
        log_file = 'log/debug.log'
        log_content = []
        log_content += [line for line in open(log_file, 'r', encoding='UTF-8')]
        extra_context = extra_context or {}
        extra_context["context"] = log_content
        response = super().changelist_view(
            request,
            extra_context=extra_context
        )
        return response

建立admin模板

具体见:https://docs.djangoproject.com/zh-hans/4.2/ref/contrib/admin/#overriding-admin-templates

CSS 变量的列表在 django/contrib/admin/static/admin/css/base.css 中定义。

在admin中指定自定义的模板路径 ModelAdmin.change_list_template¶ 自定义模板的路径,由 changelist_view() 使用。

在官网中介绍的是在extra_context中添加自己要添加的数据

py 复制代码
def change_view(self, request, object_id, form_url="", extra_context=None):
        extra_context = extra_context or {}
        extra_context["osm_data"] = self.get_osm_info()
        return super().change_view(
            request,
            object_id,
            form_url,
            extra_context=extra_context,
        )

而通过测试,在 response.context_data['要添加的数据key'] 中添加数据,也是可以找到的

我是要在后台显示日志中的内容,通过heightlight的代码显示部分

html 复制代码
{% extends 'admin/change_list.html' %}
{% load static %}
{% block content_title %}
    <!-- ECharts单文件引入 -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.18.1/styles/default.min.css">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.18.1/highlight.min.js"></script>
{% endblock %}
 
{% block result_list %}
管理领导浏览查看(循环显示,不做统计)
<script>hljs.initHighlightingOnLoad();</script>
<pre><code>
{% for line in context|slice:"::-1" %}{{ line }}{% endfor %}
</code></pre>
{% endblock %}

最终的效果就是把log日志中的内容,展示在后台显示了

欢迎大家在评论中交流提问

相关推荐
u0109147602 小时前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
baidu_340998822 小时前
Golang怎么用go-noescape优化性能_Golang如何使用编译器指令控制逃逸分析行为【进阶】
jvm·数据库·python
m0_678485452 小时前
如何利用虚拟 DOM 实现无痕刷新?基于 VNode 对比的状态保持技巧
jvm·数据库·python
qq_342295822 小时前
CSS如何实现透明背景效果_通过RGBA色彩模式控制透明度
jvm·数据库·python
TechWayfarer2 小时前
知乎/微博的IP属地显示为什么偶尔错误?用IP归属地查询平台自检工具3步验证
网络·python·网络协议·tcp/ip·网络安全
Greyson12 小时前
CSS如何处理超长文本换行问题_结合word-wrap属性
jvm·数据库·python
justjinji3 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python
小江的记录本3 小时前
【网络安全】《网络安全常见攻击与防御》(附:《六大攻击核心特性横向对比表》)
java·网络·人工智能·后端·python·安全·web安全
贵沫末3 小时前
python——打包自己的库并安装
开发语言·windows·python
weixin_580614003 小时前
MySQL存储过程中如何防止SQL注入_使用参数化查询规范
jvm·数据库·python