时间:2021-05-23
admin
admin 是 Django 自带的后台管理组件,你可以在 admin 中执行增删改查等操作。
它以可视化的方式让你来操纵模型表,十分的便捷。
基本使用
数据准备
如下,在 app01 中有一个这样的模型表:
from django.db import models# Create your models here.class User(models.Model): user_id = models.AutoField(primary_key=True, verbose_name="用户编号") user_name = models.CharField(max_length=32, verbose_name="用户名") user_gender = models.BooleanField( choices=([0, "male"], [1, "female"]), verbose_name="用户性别") user_introduction = models.TextField( max_length=1024, null=True, blank=True, verbose_name="用户简介") def __str__(self): return self.user_name创建用户
当运行了数据库迁徙命令后,需要创建一个可登录 admin 进行管理的超级账户。
python manage.py createsuperuser它会提示你输入用户名,以及密码,密码不能少于八位。
可以选填邮箱。
注册admin
管理员用户创建完成后,在 app01 应用下进行注册。
from django.contrib import adminfrom .models import *admin.site.register(User)接下来打开 admin ,输入账户名与密码后,就可以看到这张表。
接下来就可以对该表进行增删改查了。
深度配置
models参数
在创建模型表时,可以对字段添加一些与 admin 相关的参数。
参数 描述 verbose_name Admin中显示的字段名称 blank Admin中进行添加或编辑时,该字段是否可以为空 editable Admin中是否可编辑该字段 help_text Admin中的帮助信息 choices Admin中选择框显示的内容
在这里的 blank 与 verbose_name 以及 choices 都比较常用。
除了在模型表的字段上进行配置外,也可以在该表下定制元信息。这其中有关于该表在 Admin 中的信息显示,如下所示:
class User(models.Model): 字段 = 类型(条件) 字段 = 类型(条件) class Meta: verbose_name = "Admin中显示的表名"admin配置
如果要对一个注册的表进行深度配置,可在 admin.py 中对它进行。
常用的配置方式有两种,如下所示:
from django.contrib import admin# 装饰器注册@admin.register(User)class UserConfig(admin.ModelAdmin): 配置项.... # 使用siteclass UserConfig(admin.ModelAdmin): 配置项....admin.site.register(CustomAdmin, UserConfig) # 应用配置项下面是 admin 深度配置的一些常用选项。
from django.contrib import adminfrom .models import *# Register your models here.class UserConfig(admin.ModelAdmin): # 自定义字段,作用显示 def edit(self): return "编辑" # 以下是自定义admin的使用 # 添加数据模板页 # 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 # 弹出框模板页 # popup_response_template = None # 不支持多对多字段,展示表中的字段。 list_display = ["user_id", "user_name","user_gender",edit] # 点击字段可进入change页面 list_display_links = [edit] # 过滤筛选,支持各种关系 list_filter = ["user_gender"] # 支持在页面修改的字段,与list_display_links有冲突 list_editable = ["user_name"] # 模糊搜索,可以按照编号、名字搜索.或关系 search_fields = ["user_id","user_name"] # 用于和action定制项做批处理 def patch_init(self,request,queryset): """ queryset:选中的字典 """ # 选中的用户全改为男性... queryset.update(user_gender=False) # 添加描述 patch_init.short_description = "批量修改性别" actions = [patch_init] admin.site.register(User)以下是配置完成后的样式,自行对应配置项进行配置后查看即可。
中文显示
如果想要在 admin 中进行中文显示,则可以在全局的 settings.py 中配置语言。
# LANGUAGE_CODE = 'en-us'LANGUAGE_CODE = 'zh-Hans' # 中文显示执行流程
在启动 django 项目时,第一步会去 settings 中导入各种模块。
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'app01.apps.App01Config',]查看 admin 源码 from django.contrib import admin ,它下面有这样的一个函数,该函数的作用就是将所有 app 下的 admin 都会做一次导入。
def autodiscover(): autodiscover_modules('admin', register_to=site)我们知道,在模块导入时,会运行该模块中的代码,那么在 admin.site 进行注册时,实际上是应用单例模式进行注册。
使用 admin.site.register() 实际上都是在使用单例对象下的方法,并不会重复生成多个对象。
class AdminSite(object): def __init__(self): self._registry = {} def register(self, model, admin_class = None): # 设置配置类 if not admin_class: admin_class = ModelAdmin self._registry[model] = admin_class(model, self)site = AdminSite() # 最后一行admin 中单例对象的应用也非常简单,它是以模块的方式应用单例对象,因为我们知道模块只会执行一次。
如下所示:
# f1.py 模块class Test(object): def __init__(self,name): self.name = namet1 = Test("测试")当其他文件进行多次导入时,只会导入一次,此时使用的 t1 永远都是单例对象,不会重复实例化:
import f1f1.t1()以上就是Django admin组件的使用的详细内容,更多关于Django admin组件的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
admin组件使用Django提供了基于web的管理工具。Django自动管理工具是django.contrib的一部分。你可以在项目的settings.py中
关于admin:(1)admin的概述:admin是一个django子代的组件,当创建一个项目会后,就会在settings文件的INSTALLED_APPS中自
前言django的admin是个非常方便的adminportal,可以根据自己的需要重写.在使用Django自带的admin后台的时候,他提供了一些默认的指令可
1、创建一个django项目使用django-admin.pystartprojectMyDjangoSite参考这里2、建立视图fromdjango.http
使用pip安装Django时报错,先是:C:\Users\admin>pipinstalldjangoCollectingdjangoRetrying(Retr