Django 系列官方教程[7]Customizing the admin site

2023-11-25 05:30

本文主要是介绍Django 系列官方教程[7]Customizing the admin site,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

续第六章,开始自定义后台

一、自定义后台

通过问题模型admin.site.register(Question),Django能够构造一个默认的表单。通常,您需要自定义管理表单的外观和工作方式。您可以通过修改注册对象告诉Django所需的选项。


让我们通过对编辑表单上的字段进行重新排序来了解其工作原理。修改polls/admin.py中的admin.site.register(Question) :

from django.contrib import adminfrom .models import Questionclass QuestionAdmin(admin.ModelAdmin):fields = ['pub_date', 'question_text']admin.site.register(Question, QuestionAdmin)

接下来我们创建管理员admin的类,将其传递到admin.site.register(),每次我们需要改变管理员选项就调用它。

上面的这个更改使“发布日期”位于“问题”字段之前

对于只有两个字段的管理表单来说,这并不令人印象深刻,但是对于有几十个字段的管理表单来说,选择直观的顺序是一个重要的可用性细节。
说到有几十个字段的表单,您可能希望将表单拆分为字段集:

修改polls/admin.py

from django.contrib import adminfrom .models import Questionclass QuestionAdmin(admin.ModelAdmin):fieldsets = [(None,               {'fields': ['question_text']}),('Date information', {'fields': ['pub_date']}),]admin.site.register(Question, QuestionAdmin)

发现顺序改变了。

二、添加相关的要素

from django.contrib import adminfrom .models import Choice, Question
# ...
admin.site.register(Choice)

我们可以添加choice了。但实际上,这是一种向系统中添加Choice对象的低效方法。如果在创建问题对象时可以直接添加一组选项,那就更好了。让我们实现这一点。

from django.contrib import adminfrom .models import Choice, Questionclass ChoiceInline(admin.StackedInline):model = Choiceextra = 3class QuestionAdmin(admin.ModelAdmin):fieldsets = [(None,               {'fields': ['question_text']}),('Date information', {'fields': ['pub_date'], 'classes': ['collapse']}),]inlines = [ChoiceInline]admin.site.register(Question, QuestionAdmin)

这样我们就有了三个可以额外编辑的选项了。

工作原理是这样的:有三个插槽用于相关的选择(由extra指定),每次您返回到已创建对象的“更改”页面时,都会获得另外三个插槽。


在当前三个插槽的末尾,你会发现一个“添加另一个选项”链接。如果你点击它,一个新的插槽将被添加。如果要删除添加的插槽,请单击右侧的插槽顶部的X。

不过有一个小问题。显示输入相关选择对象的所有字段需要很大的屏幕空间。因此,Django提供了一种显示内联相关对象的表格方式。要使用它,请将ChoiceOnline声明更改为:

class ChoiceInline(admin.TabularInline):

三、自定义修改界面

现在,问题管理页面看起来不错,让我们对“更改列表”页面进行一些调整,让页面显示系统中的所有问题。

 这会儿界面是这样。

Django默认显示每个对象的str(),但是有时候显示单个字段会更好点,所以我们需要修改admin.py中的list_display,里面是所有需要展示的字段的名称。

class QuestionAdmin(admin.ModelAdmin):# ...list_display = ('question_text', 'pub_date')

我们来加入一个字段。

class QuestionAdmin(admin.ModelAdmin):# ...list_display = ('question_text', 'pub_date', 'was_published_recently')

展示的属性变多了。

我们还可以点击标题对列表进行排序。

另外was_published_recently在存储时会用空格替换下划线。显示为false感觉不太直观,所以我们来修改以下polls/models.py

from django.contrib import adminclass Question(models.Model):# ...@admin.display(boolean=True,ordering='pub_date',description='是不是过去发布的?',)def was_published_recently(self):now = timezone.now()return now - datetime.timedelta(days=1) <= self.pub_date <= now

我们这会儿来添加一个过滤器filter,在polls/admin.py中添加

list_filter = ['pub_date']

 

显示的筛选器类型取决于要筛选的字段类型。因为pub_date是一个DateTimeField,Django知道提供适当的筛选选项:“任意日期”、“今天”、“过去7天”、“本月”、“今年”。

这一切进展顺利。让我们添加一些搜索功能:

search_fields = ['question_text']

这会在更改列表的顶部添加一个搜索框。当有人输入搜索词时,Django将搜索question_text字段。您可以使用任意数量的字段——尽管因为它在幕后使用了like查询,将搜索字段的数量限制在合理的范围内会使数据库更容易进行搜索。


现在也是一个值得注意的好时机,更改列表为您提供了免费分页功能。默认情况下,每页显示100个项目。更改列表分页、搜索框、筛选器、日期层次结构和列标题排序都像您认为的那样协同工作。

四、自定义后台外观

现在我们的左上角仍然是django管理几个字,这可不行。

在项目目录(包含manage.py的目录)中创建模板目录。模板可以存在于文件系统中Django可以访问的任何地方。(Django以服务器运行的任何用户的身份运行。)然而,在项目中保留模板是一个很好的习惯。

所以首先打开mysite/settings.py

TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [BASE_DIR / 'templates'],'APP_DIRS': True,'OPTIONS': {'context_processors': ['django.template.context_processors.debug','django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},
]

就像静态文件一样,我们可以将所有模板放在一个大的模板目录中,它会非常好地工作。但是,属于特定应用程序的模板应该放在该应用程序的模板目录(例如轮询/模板)中,而不是放在项目的模板目录中。我们将在下一章更详细地讨论为什么要这样做。

现在在templates内部创建一个名为admin的目录,将admin/base_site.html复制进去,这个文件位于

 python -c "import django; print(django.__path__)"

现在修改这个文件类似于

{% block branding %}
<h1 id="site-name"><a href="{% url 'admin:index' %}">站点名称</a></h1>
{% endblock %}

这是覆盖模板的一种方式,通常我们还会修改django.contrib.admin.AdminSite.site_header来自定义。

Django的任何模板都可以这样修改。

聪明的读者会问:如果DIRS默认为空,Django是如何找到默认的管理模板的?答案是,由于APP_DIRS设置为True,Django会自动在每个应用程序包中查找模板/子目录,作为备用(不要忘记Django.contrib.admin是一个应用程序)。


我们的投票应用程序不是很复杂,不需要定制管理模板。但是,如果它变得更复杂,并且需要修改Django的标准管理模板来实现其某些功能,那么修改应用程序的模板,而不是项目中的模板,会更明智。这样,您就可以在任何新项目中包含polls应用程序,并确保它会找到所需的自定义模板。

同样,您可能希望定制Django首页的外观。


默认情况下,它会按字母顺序显示已在管理应用程序中注册的已安装应用程序中的所有应用程序。您可能需要对布局进行重大更改。毕竟,索引可能是管理员最重要的页面,应该很容易使用。


要自定义的模板是admin/index.html。(与上一节中的admin/base_site.html相同–将其从默认目录复制到自定义模板目录)。编辑这个文件,你会看到它使用了一个名为app_list的模板变量。该变量包含所有已安装的Django应用程序。你可以用任何你认为最好的方式对特定于对象的管理页面的链接进行硬编码,而不是使用它。

这篇关于Django 系列官方教程[7]Customizing the admin site的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/423187

相关文章

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地