admin组件使用
Django 提供了基于 web 的管理工具.
Django 自动管理工具是 django.contrib 的一部分.你可以在项目的settings.py 中的 INSTALLED_APPS 看到它:
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
"app01"
]
django.contrib 是一套庞大的功能集,它是 Django 基本代码的组成部分.
激活管理工具
通常我们在生成项目时会在 urls.py 中自动设置好,
from django.conf.urls import url
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
]
当这一切都配置好后,Django 管理工具就可以运行了.
使用管理工具
启动开发服务器,然后在浏览器中访问 http://127.0.0.1:8000/admin/,得到登陆界面,你可以通过命令 python manage.py createsuperuser 来创建超级用户。
为了让 admin 界面管理某个数据模型,我们需要先注册该数据模型到 admin
eg:
models.py
from django.db import models
# Create your models here.
class Author(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=32)
age=models.IntegerField()
# 与AuthorDetail建立一对一的关系
authorDetail=models.OneToOneField(to="AuthorDetail",on_delete=models.CASCADE)
def __str__(self):
return self.name
class AuthorDetail(models.Model):
nid = models.AutoField(primary_key=True)
birthday=models.DateField()
telephone=models.BigIntegerField()
addr=models.CharField( max_length=64)
def __str__(self):
return str(self.telephone)
class Publish(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=32)
city=models.CharField( max_length=32)
email=models.EmailField()
def __str__(self):
return self.name
class Book(models.Model):
nid = models.AutoField(primary_key=True)
title = models.CharField( max_length=32)
publishDate=models.DateField()
price=models.DecimalField(max_digits=5,decimal_places=2)
# 与Publish建立一对多的关系,外键字段建立在多的一方
publish=models.ForeignKey(to="Publish",to_field="nid",on_delete=models.CASCADE)
# 与Author表建立多对多的关系,ManyToManyField可以建在两个模型中的任意一个,自动创建第三张表
authors=models.ManyToManyField(to='Author',)
def __str__(self):
return self.title
admin.py
from app01.models import Book
from app01.models import Publish
from app01.models import Author
from app01.models import AuthorDetail
admin.site.register(Book)
admin.site.register(Publish)
admin.site.register(Author)
admin.site.register(AuthorDetail)
admin定制
在 admin.py 中只需要将 Mode 中的某个类注册,即可在Admin中实现增删改查的功能,如:
admin.site.register(Book)
但是,这种方式比较简单,如果想要进行更多的定制操作,需要利用ModelAdmin进行操作,如:
# 方式一:
class BookConfig(admin.ModelAdmin):
list_display = ["title","price","publishDate"]
admin.site.register(Book,BookConfig) # 第一个参数可以是元祖
# 方式二:
@admin.register(Book,BookConfig) # 第一个参数可以是元祖
class BookConfig(admin.ModelAdmin):
list_display = ["title","price","publishDate"]
我们为什么要继承admin.ModelAdmin呢?这就得看admin源码了.
首先我们看admin.site.register的register到底干了什么
ModelAdmin就是默认的定制类
image.png
ModelAdmin中提供了大量的可定制功能,如
1.list_display,列表时,定制显示的列
class BookConfig(admin.ModelAdmin):
list_display = ["title","price","publishDate"]
image.png
- list_display_links,列表时,定制列可以点击跳转。
class BookConfig(admin.ModelAdmin):
list_display = ["title","price","publishDate"]
list_display_links = ["title","price","nid"]
image.png
(media/15319841381000/15320774163440.jpg)
-
list_filter,列表时,定制右侧快速筛选。
image.png
list_filter = ["publish","authors"]
-
list_select_related,列表时,连表查询是否自动select_related
-
list_editable,列表时,可以编辑的列
# 注意事项 list_editable 里边的字段必须包含在 list_display 不包含在 list_display_links
# <class 'app01.admin.BookConfig'>: (admin.E122) The value of 'list_editable[0]' refers to 'authors', which is not contained in 'list_display'.
# <class 'app01.admin.BookConfig'>: (admin.E123) The value of 'title' cannot be in both 'list_editable' and 'list_display_links'.
list_editable = ['publishDate',]
image.png
- search_fields,列表时,模糊搜索的功能
# 搜索框内输入关键字过滤的字段
search_fields = ['price', 'title']
image.png
(media/15319841381000/15322648400241.jpg)
- date_hierarchy,列表时,对Date和DateTime类型进行搜索
date_hierarchy = 'ctime'
image.png
image.png
8 inlines,详细页面,如果有其他表和当前表做FK,那么详细页面可以进行动态增加和删除
# 仅供参考 eg:
class UserInfoInline(admin.StackedInline): # TabularInline
extra = 0
model = models.UserInfo
class GroupAdminMode(admin.ModelAdmin):
list_display = ('id', 'title',)
inlines = [UserInfoInline, ]
9 action,列表时,定制action中的批量操作
def patch_init(self,request,queryset):
queryset.update(price=100)
patch_init.short_description = '价格初始化"100"'
actions = [patch_init] # 你可以定义多个函数,写到列表里
# Action选项都是在页面上方显示
actions_on_top = True
# Action选项都是在页面下方显示
actions_on_bottom = False
# 是否显示选择个数
actions_selection_counter = True
image.png
image.png
10 定制HTML模板
# 仅供参考 eg:
add_form_template = None
change_form_template = None
change_list_template = None
delete_confirmation_template = None
delete_selected_confirmation_template = None
object_history_template = None
11 raw_id_fields,详细页面,针对FK和M2M字段变成以Input框形式
# 仅供参考 eg:
raw_id_fields = ('FK字段', 'M2M字段',)
12 fields,详细页面时,显示字段的字段
# 仅供参考 eg:
fields = ('user',)
13 exclude,详细页面时,排除的字段
# 仅供参考 eg:
exclude = ('user',)
14 readonly_fields,详细页面时,只读字段
# 仅供参考 eg:
readonly_fields = ('user',)
15 fieldsets,详细页面时,使用fieldsets标签对数据进行分割显示
# 仅供参考 eg:
fieldsets = (
('基本数据', {
'fields': ('user', 'pwd', 'ctime',)
}),
('其他', {
'classes': ('collapse', 'wide', 'extrapretty'), # 'collapse','wide', 'extrapretty'
'fields': ('user', 'pwd'),
}),
)
16 详细页面时,M2M显示时,数据移动选择(方向:上下和左右)
# 仅供参考 eg:
filter_vertical = ("m2m字段",) # 或filter_horizontal = ("m2m字段",)
17 ordering,列表时,数据排序规则
# 仅供参考 eg:
ordering = ('-id',)
或
def get_ordering(self, request):
return ['-id',
- radio_fields,详细页面时,使用radio显示选项(FK默认使用select)
# 仅供参考 eg:
radio_fields = {"ug": admin.VERTICAL} # 或admin.HORIZONTAL
19 form = ModelForm,用于定制用户请求时候表单验证
# 仅供参考 eg:
from app01 import models
from django.forms import ModelForm
from django.forms import fields
class MyForm(ModelForm):
others = fields.CharField()
class Meta:
model = models = models.UserInfo
fields = "__all__"
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
form = MyForm
20 empty_value_display = "列数据为空时,显示默认值"
@admin.register(models.UserInfo)
class UserAdmin(admin.ModelAdmin):
empty_value_display = "列数据为空时,默认显示"
list_display = ('user','pwd','up')
def up(self,obj):
return obj.user
up.empty_value_display = "指定列数据为空时,默认显示"
网友评论