Django-admin管理工具使用

2018-07-22  本文已影响0人  墨颜丶

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到底干了什么

image.png
ModelAdmin就是默认的定制类
image.png

ModelAdmin中提供了大量的可定制功能,如
1.list_display,列表时,定制显示的列

class BookConfig(admin.ModelAdmin):
    list_display = ["title","price","publishDate"]
image.png
  1. list_display_links,列表时,定制列可以点击跳转。
class BookConfig(admin.ModelAdmin):
    list_display = ["title","price","publishDate"]
    list_display_links = ["title","price","nid"]

image.png

(media/15319841381000/15320774163440.jpg)

  1. list_filter,列表时,定制右侧快速筛选。
    list_filter = ["publish","authors"]

    image.png
  2. list_select_related,列表时,连表查询是否自动select_related

  3. 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
  1. search_fields,列表时,模糊搜索的功能
# 搜索框内输入关键字过滤的字段
    search_fields = ['price', 'title']
image.png

(media/15319841381000/15322648400241.jpg)

  1. 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', 
  1. 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 = "指定列数据为空时,默认显示"
上一篇 下一篇

猜你喜欢

热点阅读