详解Django admin高级用法

详解Django admin高级用法

Django admin是Django自带的管理员后台管理系统,可以方便地进行数据库管理,数据展示,数据处理等功能。本文将详细讲解如何使用Django admin的高级用法。

1. 自定义管理器

在Django admin中,如果希望对某个Model进行管理时,需要先创建一个管理器类,例如:

from django.contrib import admin
from .models import Author

class AuthorAdmin(admin.ModelAdmin):
    pass

admin.site.register(Author, AuthorAdmin)

这里创建了一个AuthorAdmin类,继承了admin.ModelAdmin类,并将Author和AuthorAdmin进行了注册,这样我们就可以在Django admin中管理Author的数据了。

但是,有时候我们可能需要对数据进行一些特殊处理,比如只让管理员看到某个字段,只有某些用户才有权限对某个Model进行管理等操作。这时候就需要自定义管理器了。

1.1 隐藏字段

有时候某个Model中有敏感数据,不希望普通管理员看到,可以通过自定义管理器隐藏掉该字段:

class AuthorAdmin(admin.ModelAdmin):
    exclude = ('email',)

这样管理员在Django admin中就看不到email字段了。

1.2 只读字段

有时候某个Model中有重要数据,只允许查看,不允许修改,可以通过自定义管理器将该字段设置为只读:

class AuthorAdmin(admin.ModelAdmin):
    readonly_fields = ('name',)

这样管理员在Django admin中可以看到name字段,但是不能修改。

1.3 重写默认查询方法

如果默认的查询方法无法满足我们的需求,可以通过自定义管理器重写查询方法。例如,我们希望只显示未删除的数据:

class AuthorAdmin(admin.ModelAdmin):
    def get_queryset(self, request):
        qs = super(AuthorAdmin, self).get_queryset(request)
        qs = qs.filter(is_deleted=False)
        return qs

这样在Django admin中就只会显示is_deleted为False的数据了。

2. 自定义Django admin页面

Django admin默认使用Bootstrap样式,但是有时候我们可能需要自定义页面样式,比如加入自己的CSS或JS文件。这时候就需要自定义Django admin页面了。

2.1 添加静态文件

首先我们需要在Django的静态文件目录中创建一个文件夹,用来存放我们需要的CSS或JS文件, 例如新建一个名为'admin_custom'的文件夹。然后我们需要在Django项目中找到settings.py文件,并且离线添加以下代码:

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'admin_custom')
]

这里我们将新建的'admin_custom'文件夹添加到静态文件目录中。

2.2 自定义页面模板

接下来我们需要自定义页面模板,在'appname/templates/admin'目录下,新建一个名为'appname/change_form.html'的文件,这个文件可以作为管理员对某个Model记录进行更改时的模板。在这个模板中,我们可以引入之前添加的CSS或JS文件:

{% extends "admin/change_form.html" %}
{% block extrahead %}
    {{ block.super }}
    <link rel="stylesheet" type="text/css" href="{% static 'admin_custom/admin.css' %}">
{% endblock %}

这里的'admin_custom/admin.css'是我们在admin_custom文件夹中新建的CSS文件,可以使用该文件自定义Django admin中的样式。

2.3 自定义页面元素

最后,我们可以通过自定义页面元素来替换Django admin默认的元素,例如隐藏Django admin中默认的某些按钮:

{% extends "admin/change_form.html" %}
{% block submit_buttons_bottom %}
{% endblock %}

这里通过重写submit_buttons_bottom块,将Django admin中的提交按钮隐藏了。

示例说明

示例1:在Django admin中添加自定义页面

假设我们需要在Django admin中添加一个自定义的页面,用于展示系统的性能状况,包括CPU使用率、内存使用率等数据。

首先,我们需要创建一个Model,用于存储这些数据。然后创建一个自定义的管理器,重写默认的查询方法,使其只显示最近一笔数据。最后我们创建一个自定义的页面模板,在其中引用自己编写的CSS文件和JS文件,用于展示数据。

示例2:自定义Django admin的页面元素

假设我们需要自定义Django admin中的Model表单页面,去掉一些权限不足的用户不需要的字段。我们可以通过自定义管理器,使用exclude来隐藏某些字段;使用readonly_fields来设置只读字段;或者重写默认的查询方法,只查询该用户有权限查看的数据。

然后我们可以自定义页面元素,例如隐藏某些按钮,以实现更好的用户体验。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:详解Django admin高级用法 - Python技术站

(0)
上一篇 2023年5月16日
下一篇 2023年5月16日

相关文章

  • django从请求到响应的过程深入讲解

    当请求发出后,Django将会执行一系列的处理步骤,最终生成对应的响应,这个过程可以分为以下几步: 1. 请求接收 当用户在浏览器中输入URL请求网页时,Django将会接收到这个请求。这个请求将会被一个称为WSGI的Python规范所捕获,然后交给Django进行处理。在Django应用程序中,这部分处理由WSGI服务器负责。 2. URL匹配和视图解析 …

    Django 2023年5月16日
    00
  • 如何进行Django单元测试

    如何进行Django单元测试 Django的单元测试使用python的unittest模块,这个模块使用基于类的方法来定义测试。类名为django.test.TestCase,继承于python的unittest.TestCase。   执行目录下所有的测试(所有的test*.py文件):运行测试的时候,测试程序会在所有以test开头的文件中查找所有的tes…

    Django 2023年4月10日
    00
  • Django Rest Framework之版本控制

    settings.py: REST_FRAMEWORK = { ‘DEFAULT_VERSION’: ‘v1’, # 默认版本 ‘ALLOWED_VERSIONS’: [‘v1’, ‘v2’], # 允许的版本 ‘VERSION_PARAM’: ‘version’ # URL中获取值的key }  urls.py: from django.conf.urls…

    2023年4月9日
    00
  • Django开发的简易留言板案例详解

    下面我详细讲解一下“Django开发的简易留言板案例详解”的完整攻略。 前言 本文主要讲解使用Django框架开发简易留言板的过程和实现步骤,旨在帮助初学者学习Django框架,并对Django框架的开发方式有一个更深入的了解。在本文中,将涉及到Django框架的环境配置、数据库的操作和后端代码的编写等内容。 环境搭建 在开始搭建环境前,我们需要确保已经在本…

    Django 2023年5月16日
    00
  • django导入环境变量 Please specify Django project root directory

    在创建了套层的文件后,django需要的解释器也需要重新设置,普通的设置明显不能用,那么该如何解决呢 下图:    点击OK       依次点击 apply 和 ok  

    Django 2023年4月13日
    00
  • Pycharm搭建一个Django项目的方法步骤

    接下来我将为您详细讲解在Pycharm中搭建Django项目的方法步骤,以及两个示例。 步骤一:创建Django项目 打开Pycharm,点击“Create New Project”新建一个项目; 在新项目的创建页面中,选择“Django”,并填写项目名称和保存路径,点击“Create”创建项目; 在创建完项目后,如果您的Pycharm没有自动打开Djang…

    Django 2023年5月16日
    00
  • Python笔记(五)–Django中使用模板

      使用Django开发网站时,如果不使用模板,那么将会很不合理。因为我们所有的html代码都需要被硬编码到我们的Python代码中。我们新建一个工程,然后再在新建一个应用程序,并在其中的views.py文件中添加如下代码: 1 #coding=UTF-8 2 from django.http.response import HttpResponse, Ht…

    Django 2023年4月12日
    00
  • Django 2.0版本的新特性抢先看!

    Django 2.0版本的新特性抢先看! Django 2.0版本已经正式推出,本文将为大家介绍其中的一些新特性和优化,以及如何在项目中应用。 引入Python 3.4以上版本的支持 Django 2.0开始将不再支持Python 2.7版本,而是引入Python 3.4及以上版本的支持,这意味着应用Django 2.0版本的项目,需要将Python版本升级…

    Django 2023年5月16日
    00
合作推广
合作推广
分享本页
返回顶部