文章目录
1 Admin站点的使用
假设我们要设计一个新闻网站,我们需要编写展示给用户的页面,网页上展示的新闻信息是从哪里来的呢?是从数据库中查找到新闻的信息,然后把它展示在页面上。但是我们的网站上的新闻每天都要更新,这就意味着对数据库的增、删、改、查操作,那么我们需要每天写sql语句操作数据库吗? 如果这样的话,是不是非常繁琐,所以我们可以设计一个页面,通过对这个页面的操作来实现对新闻数据库的增删改查操作。
那么问题来了,老板说我们需要再建立一个新网站,是不是还要设计一个页面来实现对新网站数据库的增删改查操作,但是这样的页面具有一个很大的重复性,那有没有一种方法能够让我们很快的生成管理数据库表的页面呢?有,那就是Django的后台管理。Django能够根据定义的模型类自动地生成管理页面。
使用Django的管理模块,需要按照如下步骤操作:
1.管理界面本地化
2.创建管理员
3.注册模型类
4.自定义管理页面
1.1 管理界面本地化
在settings.py中设置语言和时区
LANGUAGE_CODE = 'zh-hans' # 使用中国语言
TIME_ZONE = 'Asia/Shanghai' # 使用中国上海时间
1.2 创建超级管理员
创建管理员的命令如下,按提示输入用户名、邮箱、密码。
python manage.py createsuperuser

如果想要修改密码可以执行
python manage.py changepassword 用户名
打开浏览器,在地址栏中输入如下地址后回车。
http://127.0.0.1:8000/admin/

输入用户名密码,登录成功后界面如下:

但是并没有我们自己应用模型的入口,接下来进行第三步操作。
1.3 App应用配置
在每个应用目录中都包含了apps.py文件,用于保存该应用的相关信息。
在创建应用时,Django会向apps.py文件中写入一个该应用的配置类,如
from django.apps import AppConfig
class BooksConfig(AppConfig):
name = 'books'
我们将此类添加到工程settings.py中的INSTALLED_APPS列表中,表明注册安装具备此配置属性的应用:

AppConfig.name 属性表示这个配置类是加载到哪个应用的,每个配置类必须包含此属性,默认自动生成。
AppConfig.verbose_name 属性用于设置该应用的直观可读的名字,此名字在Django提供的Admin管理站点中会显示,如
from django.apps import AppConfig
class BooksConfig(AppConfig):
name = 'books'
verbose_name = '图书管理'
1.4 注册模型类
登录后台管理后,默认没有我们创建的应用中定义的模型类,需要在自己应用中的admin.py文件中注册,才可以在后台管理中看到,并进行增删改查操作。
打开books/admin.py文件,编写如下代码:
from django.contrib import admin
from books.models import BookInfo,HeroInfo
admin.site.register(BookInfo)
admin.site.register(HeroInfo)
到浏览器中刷新页面,可以看到模型类BookInfo和HeroInfo的管理了:

点击"图书"(BookInfo类)可以进入列表页,默认只有一列:

在列表页右上角点击"增加 图书"可以进入增加页,

Django会根据模型类的不同,生成不同的表单控件,按提示填写表单内容后点击"保存",完成数据创建,创建成功后返回列表页。

按照提示进行内容的修改,修改成功后进入列表页。在修改页点击“删除”可以删除一项:

注意:不勾选逻辑删除的话,它就是物理删除,谨慎操作
点击执行后进入确认页面,删除后回来列表页面。

本文详细介绍了Django后台管理的配置与使用,包括管理界面本地化、创建超级管理员、App应用配置、模型类注册、Admin管理类定义等步骤。此外,还展示了如何调整列表页和编辑页的展示,如页大小、操作选项位置、列表列、关联对象、搜索框等。同时,介绍了图片上传的配置和处理。通过这些设置,可以高效地管理数据库表,提高工作效率。
最低0.47元/天 解锁文章
539

被折叠的 条评论
为什么被折叠?



