Admin站点
管理界面本地化
在settings.py中设置语言和时区
LANGUAGE_CODE = 'zh-hans' # 使用中国语言
TIME_ZONE = 'Asia/Shanghai' # 使用中国上海时间
创建超级管理员
创建管理员的命令如下,按提示输入用户名、邮箱、密码。
python manage.py createsuperuser
访问ip:
http://127.0.0.1:8000/admin/
注册模型类
默认没有我们创建的应用中定义的模型类,需要在自己应用中的admin.py文件中注册
from django.contrib import admin
from booktest.models import BookInfo,HeroInfo
admin.site.register(BookInfo)
admin.site.register(HeroInfo)
定义与使用Admin管理类
Django提供的Admin站点的展示效果可以通过自定义ModelAdmin类来进行控制。
定义管理类需要继承自admin.ModelAdmin类,如下
from django.contrib import admin
class BookInfoAdmin(admin.ModelAdmin):
pass
使用管理类有两种方式:
-
注册参数
admin.site.register(BookInfo,BookInfoAdmin)
-
装饰器
@admin.register(BookInfo) class BookInfoAdmin(admin.ModelAdmin): pass
调整列表页展示
页大小
每页中显示多少条数据,默认为每页显示100条数据,属性如下:
list_per_page=100
打开booktest/admin.py文件,修改AreaAdmin类如下:
class BookInfoAdmin(admin.ModelAdmin):
list_per_page = 2
"操作选项"的位置
顶部显示的属性,设置为True在顶部显示,设置为False不在顶部显示,默认为True。
actions_on_top=True
底部显示的属性,设置为True在底部显示,设置为False不在底部显示,默认为False。
actions_on_bottom=False
class BookInfoAdmin(admin.ModelAdmin):
...
actions_on_top = True
actions_on_bottom = True
列表中的列
属性如下:
list_display=[模型字段1,模型字段2,...]
class BookInfoAdmin(admin.ModelAdmin):
...
list_display = ['id','btitle']
将方法作为列
列可以是模型字段,还可以是模型方法,要求方法有返回值。
通过设置short_description属性,可以设置在admin站点中显示的列名。
class BookInfo(models.Model):
...
def pub_date(self):
return self.bpub_date.strftime('%Y年%m月%d日')
pub_date.short_description = '发布日期' # 设置方法字段在admin中显示的标题
class BookInfoAdmin(admin.ModelAdmin):
...
list_display = ['id','atitle','pub_date']
方法列是不能排序的,如果需要排序需要为方法指定排序依据。
admin_order_field=模型类字段
class BookInfo(models.Model):
...
def pub_date(self):
return self.bpub_date.strftime('%Y年%m月%d日')
pub_date.short_description = '发布日期'
pub_date.admin_order_field = 'bpub_date'
关联对象
无法直接访问关联对象的属性或方法,可以在模型类中封装方法,访问关联对象的成员。
class HeroInfo(models.Model):
...
def read(self):
return self.hbook.bread
read.short_description = '图书阅读量'
class HeroInfoAdmin(admin.ModelAdmin):
...
list_display = ['id', 'hname', 'hbook', 'read']
右侧栏过滤器
属性如下,只能接收字段,会将对应字段的值列出来,用于快速过滤。一般用于有重复值的字段。
list_filter=[]
class HeroInfoAdmin(admin.ModelAdmin):
...
list_filter = ['hbook', 'hgender']
搜索框
属性如下,用于对指定字段的值进行搜索,支持模糊查询。列表类型,表示在这些字段上进行搜索。
search_fields=[]
class HeroInfoAdmin(admin.ModelAdmin):
...
search_fields = ['hname']
调整编辑页展示
显示字段
属性如下:
fields=[]
class BookInfoAdmin(admin.ModelAdmin):
...
fields = ['btitle', 'bpub_date']
分组显示
属性如下:
fieldset=(
('组1标题',{'fields':('字段1','字段2')}),
('组2标题',{'fields':('字段3','字段4')}),
)
class BookInfoAdmin(admin.ModelAdmin):
...
# fields = ['btitle', 'bpub_date']
fieldsets = (
('基本', {'fields': ['btitle', 'bpub_date']}),
('高级', {
'fields': ['bread', 'bcomment'],
'classes': ('collapse',) # 是否折叠显示
})
)
关联对象
在一对多的关系中,可以在一端的编辑页面中编辑多端的对象,嵌入多端对象的方式包括表格、块两种.
- 类型InlineModelAdmin:表示在模型的编辑页面嵌入关联模型的编辑。
- 子类TabularInline:以表格的形式嵌入。
- 子类StackedInline:以块的形式嵌入。
class HeroInfoStackInline(admin.StackedInline):
model = HeroInfo # 要编辑的对象
extra = 1 # 附加编辑的数量
class BookInfoAdmin(admin.ModelAdmin):
...
inlines = [HeroInfoStackInline]
可以用表格的形式嵌入。
class HeroInfoTabularInline(admin.TabularInline):
model = HeroInfo
extra = 1
class BookInfoAdmin(admin.ModelAdmin):
...
inlines = [HeroInfoTabularInline]
调整站点信息
Admin站点的名称信息也是可以自定义的。
- admin.site.site_header 设置网站页头
- admin.site.site_title 设置页面标题
- admin.site.index_title 设置首页标语
from django.contrib import admin
admin.site.site_header = 'aaaa'
admin.site.site_title = 'bbbb'
admin.site.index_title = 'cccc'
上传图片
Django有提供文件系统支持,在Admin站点中可以轻松上传图片。
配置
默认情况下,Django会将上传的图片保存在本地服务器上,需要配置保存的路径。
将上传的文件保存在静态文件目录中,之前设置的static_files目录中在settings.py 文件中添加如下上传保存目录信息
MEDIA_ROOT=os.path.join(BASE_DIR,"static_files/media")
为模型类添加ImageField字段
class BookInfo(models.Model):
...
image = models.ImageField(upload_to='booktest', verbose_name='图片', null=True)
- upload_to 选项指明该字段的图片保存在MEDIA_ROOT目录中的哪个子目录
使用Admin站点上传图片
选择一张图片并保存后,图片会被保存在static_files/media/booktest/目录下。
在数据库中,我们能看到image字段被设置为图片的路径。