Skip to content

改造Django默认的后台

字数
771 字
阅读时间
4 分钟
更新日期
4/18/2021

Django用的时间久了会觉得挺方便,定义好model,便有一套默认的后台系统给你提供一整套的增删改查服务,对于不想写后台的懒人来说非常方便,Hacking8的信息流就是用的默认Django后台。

但有时候我想在后台里加点自定义的东西,或是展示一些数据,或是增加一些自定义的按钮,就有点束手无策了。

这几天简单看了下django admin的代码,琢磨出了一些方案。。

简单的

template新建一个admin目录,admin目录下新建一个index.html

html
{% extends "admin/index.html" %}

{% block content %}
    <div id="content-main">
        <div>
            <div class="app-diy module">
                <table>
                    <caption>
                        <span class="section"
                              title="">惊不惊喜?意不意外?</span>
                    </caption>
                    <tr>
                        <th scope="row"><a href="/">测试栏目</a></th>
                        <td></td>
                    </tr>
                </table>
            </div>
        </div>
    </div>
    {{ block.super }}
{% endblock %}

然后打开后台

image-20210417223719346

我们就在后台新增了几个可以转到自定义页面的超链接。

接下来添加一个自定义页面

新建一个diy_admin.py

python
from django.shortcuts import render
from django.template.response import TemplateResponse


def admin_diy(request):
    context = {
        'site_title': "title",
        'site_header': "header",
        'site_url': "/",
        'has_permission': True,
    }
    return render(request, "admin/admindiy.html", context)

admin目录下新建admindiy.html

html
{% 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>
                <th> xx</th>
                <th> xx</th>
                <th> xx</th>
            </tr>
            </thead>
            <tbody>
            <tr>
                <td> aa</td>
                <td> ba</td>
                <td> ca</td>
            </tr>
            <tr>
                <td> aa</td>
                <td> ba</td>
                <td> ca</td>
            </tr>
            <tr>
                <td> aa</td>
                <td> ba</td>
                <td> ca</td>
            </tr>
            <tr>
                <td> aa</td>
                <td> ba</td>
                <td> ca</td>
            </tr>
            </tbody>
        </table>
    </div>
{% endblock %}

在原 admin路由上面添加一个自定义页面的路由

image-20210417224654004

image-20210417224749731

不过可以观察到这个页面没有面包导航,也没有权限验证,任何人都能访问

看django admin的代码,添加了一些权限验证和context

python
def admin_diy(request):
    if not (request.user.is_active and request.user.is_staff):
        index_path = reverse('admin:index')
        return HttpResponseRedirect(index_path)
    context = {
        'site_title': "title",
        'site_header': "header",
        'site_url': "/",
        'title': "title2",
        'has_permission': True,
    }
    return render(request, "admin/admindiy.html", context)

image-20210417230004680

现在好多了,对于只想定义几个单页面来说,这样就足够了。

复杂一点

新建一个myadmin.py文件

python
class MyAdminSite(AdminSite):

    def get_urls(self):
        from django.urls import path

        urls = super().get_urls()
        urls += [
            path('my_view/', self.admin_view(self.diy_home), name="haha")
        ]
        return urls

    def diy_home(self, request):
        """
        Display the main admin index page, which lists all of the installed
        apps that have been registered in this site.
        """

        context = {
            **self.each_context(request),
            'title': "测试",
        }
        request.current_app = self.name

        return TemplateResponse(request, 'admin/admindiy.html', context)

admin_site = MyAdminSite(name='myadmin')

然后setting.py中INSTALLED_APPSdjango.contrib.admi替换成自己的app.myadmin.admin_site

替换admin url

原来的admin url是url(r'^admin/', admin.site.urls)替换为url(r'^admin/', admin_site)

替换register

然后在所有app下的admin.py下,admin.site.register替换为myadmin.admin_site.register

这个模式相当于继承了django admin之前的方法,继承并新增里面的url,导入到自己的设定的view中,权限验证context之类的可以直接复用它写好的就行了,但是缺点就是要将之前使用原版admin的方法都替换为我们自定义的这个新方法。

撰写

布局切换

调整 VitePress 的布局样式,以适配不同的阅读习惯和屏幕环境。

全部展开
使侧边栏和内容区域占据整个屏幕的全部宽度。
全部展开,但侧边栏宽度可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
全部展开,且侧边栏和内容区域宽度均可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
原始宽度
原始的 VitePress 默认布局宽度

页面最大宽度

调整 VitePress 布局中页面的宽度,以适配不同的阅读习惯和屏幕环境。

调整页面最大宽度
一个可调整的滑块,用于选择和自定义页面最大宽度。

内容最大宽度

调整 VitePress 布局中内容区域的宽度,以适配不同的阅读习惯和屏幕环境。

调整内容最大宽度
一个可调整的滑块,用于选择和自定义内容最大宽度。

聚光灯

支持在正文中高亮当前鼠标悬停的行和元素,以优化阅读和专注困难的用户的阅读体验。

ON开启
开启聚光灯。
OFF关闭
关闭聚光灯。

聚光灯样式

调整聚光灯的样式。

置于底部
在当前鼠标悬停的元素下方添加一个纯色背景以突出显示当前鼠标悬停的位置。
置于侧边
在当前鼠标悬停的元素旁边添加一条固定的纯色线以突出显示当前鼠标悬停的位置。