本文共 3195 字,大约阅读时间需要 10 分钟。
pip install https://codeload.github.com/sshwsfc/xadmin/zip/django2
INSTALLED_APPS = [ ... 'xadmin', 'crispy_forms', 'reversion', ... ] # 修改配置使用中文界面 LANGUAGE_CODE = 'zh-Hans' # 修改配置中的时区 TIME_ZONE = 'Asia/Shanghai'
python manage.py makemigrations python manage.py migrate
import xadmin xadmin.autodiscover() # version模块自动注册需要版本控制的 Model from xadmin.plugins import xversion xversion.register_models() urlpatterns = [ path(r'xadmin/', xadmin.site.urls), ]
python manage.py createsuperuser
每一个应用文件中(apps文件夹下的应用)都可以创建adminx.py对xadmin站点进行配置。
xadmin的站点管理类不用继承admin.ModelAdmin
,而是直接继承object
即可。
import xadmin from xadmin import views from . import models class BaseSetting(object): """xadmin的基本配置""" enable_themes = True # 开启主题切换功能 use_bootswatch = True # 引导控制盘(其实就是我们的左侧菜单栏) xadmin.site.register(views.BaseAdminView, BaseSetting) class GlobalSettings(object): """xadmin的全局配置""" site_title = "众阅生活" # 设置站点标题 site_footer = "XXX有限公司" # 设置站点的页脚 menu_style = "accordion" # 设置菜单折叠 xadmin.site.register(views.CommAdminView, GlobalSettings) 例如:对models.py中的订单记录模型类(Order)进行管理则进行如下操作 class OrderModelAdmin(object): """ 订单记录管理类 """ pass 注:可以对以下(站点Model管理)中的相关属性进行配置(字段名根据自己model类中的实际情况) xadmin.site.register(models.Order, OrderModelAdmin)
xadmin可以使用的页面样式控制基本与Django原生的admin一致。
可以在models类中定义__str__
方法来定义对象显示成什么内容
list_display 控制列表展示的字段
list_display = ['id', 'btitle', 'bread', 'bcomment']
search_fields 控制可以通过搜索框搜索的字段名称,xadmin使用的是模糊查询
search_fields = ['id','btitle']
list_filter 可以进行过滤操作的列,对于分类、性别、状态
list_filter = ['is_delete']
ordering 默认排序的字段
ordering = ['-age',] #-倒序
show_detail_fields 在列表页提供快速显示详情信息
show_detail_fields = ['id',]
list_editable 在列表页可以快速直接编辑的字段
list_editable = ['name','age',]
refresh_times 指定列表页的定时刷新
refresh_times = [5, 10,30,60] # 设置允许后端管理人员按多长时间(秒)刷新页面,选好之后就能自动刷新了
list_export 控制列表页导出数据的可选格式
list_export = ('xls', 'json','csv')#写元祖或者列表都行 list_export设置为None来禁用数据导出功能list_export_fields = ('id', 'btitle', 'bpub_date') #设置允许导出的字段
show_bookmarks 控制是否显示书签功能
show_bookmarks = True #False就隐藏了这个功能
data_charts 控制显示图表的样式
data_charts = { "order_amount": { #随便写的名称order_amount 'title': '图书发布日期表', "x-field": "bpub_date", "y-field": ('btitle',), "order": ('id',), }, # 支持生成多个不同的图表 # "order_amount2": { # 'title': '图书发布日期表', # "x-field": "bpub_date", # "y-field": ('btitle',), # "order": ('id',) # }, }
model_icon 控制菜单的图标【图标的设置可以参考font-awesome的图标css名称】
model_icon = 'fa fa-gift'
readonly_fields 在编辑页面的只读字段
readonly_fields = ['name',]
exclude 在编辑页面隐藏的字段,比如判断这个数据是否删除的delete_status字段,一般就是用来标识一下字段是不是被删除了,但是数据库中不删除
exclude = ['name',]
这并不是所有功能,可以参看它的文档,它提供的一些功能我们可能还需要自定制,调整或者添加一些它没有的功能。
转载地址:http://sknuz.baihongyu.com/