欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Django之admin管理工具

程序员文章站 2023-01-14 20:40:40
一、基本设置 1,应用注册 若要把app应用显示在后台管理中,需要在admin.py中注册。有两种方式注册 1.1 方式一: 1.2 方式二:用装饰器 2,admin界面汉化 默认admin后台管理界面是英文的,可以在settings.py中设置: LANGUAGE_CODE='zh-hans' T ......

  一、基本设置

  1,应用注册

  若要把app应用显示在后台管理中,需要在admin.py中注册。有两种方式注册

  1.1 方式一:

from django.contrib import admin
from blog.models import blog
  
#blog模型的管理器
class blogadmin(admin.modeladmin):
    list_display=('id', 'caption', 'author', 'publish_time')
     
#在admin中注册绑定
admin.site.register(blog, blogadmin)

  1.2 方式二:用装饰器

from django.contrib import admin
from blog.models import blog
  
#blog模型的管理器
@admin.register(blog)
class blogadmin(admin.modeladmin):
    list_display=('id', 'caption', 'author', 'publish_time')

  2,admin界面汉化

  默认admin后台管理界面是英文的,可以在settings.py中设置:

  language_code='zh-hans'

  time_zone='asia/shanghai'

  二、记录列表界面设置

  1,记录列表基本设置

from django.contrib import admin
from app01.models import book
from django.utils.safestring import mark_safe #blog模型的管理器 @admin.register(book) class bookadmin(admin.modeladmin):
  def _



  def authors(self,obj):
    return ','.join([obj_author for obj_author in obj.author.all()]) #listdisplay设置要显示在列表中的字段(id字段是django模型的默认主键) list_display = ('name', 'publish', 'authors', 'pub_date','price') #list_per_page设置每页显示多少条记录,默认是100条 list_per_page = 50 #ordering设置默认排序字段,负号表示降序排序 ordering = ('-price',) #list_editable 设置默认可编辑字段 list_editable = ['price'] #fk_fields 设置显示外键字段 fk_fields = ('machine_room_id',)
  #设置哪些字段可以点击进入编辑界面 list_display_links = ('name', 'pub_date')
  #筛选器 list_filter =('publish', 'author', ) #过滤器 search_fields =('name', 'net', 'mark') #搜索字段 date_hierarchy = 'go_time' # 详细时间分层筛选 
  
  #链表查询是否自动select_related
  list_select_related

  #action,定制action中的操作(批量操作)
  def func(self,request,queryset):
    queryset.update(price=100)
  func.short_description='批量初始化'
  actions=[func,]

  #定制html模板
  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

   三、admin源码解读

  1,启动所有app的admin.py文件

def autodiscover():
    autodiscover_modules('admin', register_to=site)

  2,注册模型类

class bookadmin(admin.modeladmin):      #自定义的配置类
    list_display = ("title",'publishdate', 'price')

admin.site.register(book, bookadmin) 
admin.site.register(publish)

  执行register方法:

class modeladmin:        #配置类
  pass
class adminsite: def __init__(self): self._registry = {} def register(self, model, admin_class=none, **options): admin_class = admin_class or modeladmin self._registry[model] = admin_class(model)
site=adminsite()

  注册完模型类之后,只是完成了在_registry字典里加了键值对,以模型类为键,配置类对象为值,如现在:

得到的值:
_registry={book:bookadmin(book),publish:modeladmin(publish)}
至此,注册环节完成

  3,admin的url配置

urlpatterns = [
    path('admin/', admin.site.urls),
]
class modeladmin():
    @property
    def urls(self):
        return self.get_urls(), none, none
     def get_urls(self):
        temp=[
            path('',self.list_view),
            path('add/',self.add_view),
            re_path('(\d+)/delete/',self.delete_view),
            re_path('(\d+)/edit/',self.edit_view),
        ]
        return temp
    
class adminsite:
    @property
    def urls(self):
        return self.get_urls(), 'admin', self.name
    def get_urls(self):
        temp=[]
        for model,config_obj in self._registry.items():
            model_name = model._meta.model_name
            app_label = model._meta.app_label
            temp.append(path('%s/%s/'%(app_label,model_name),config_obj.urls))
        return temp

  这就完成了url的二级分发