django-xadmin的安装

一:安装xadmin(django版本最好是2.2的)

pip3 install https://codeload.github.com/sshwsfc/xadmin/zip/django2

二:在配置文件中注册如下应用

INSTALLED_APPS = [
    ...
    'xadmin',
    'crispy_forms',
    'reversion',
    ...
]

三:修改中文显示的配置

# 修改使用中文界面
LANGUAGE_CODE = 'zh-Hans'

# 修改时区
TIME_ZONE = 'Asia/Shanghai'

四:在总路由中添加xadmin的路由信息

import xadmin
xadmin.autodiscover()

# version模块自动注册需要版本控制的 Model
from xadmin.plugins import xversion
xversion.register_models()

urlpatterns = [
    path(r'xadmin/', xadmin.site.urls),
]

五:xadmin有建立自己的数据库模型类,需要进行数据库迁移

python manage.py makemigrations
python manage.py migrate

ps:如果报错了,报的下面的错误,点过来(没有报,跳过)

ImportError : cannot import name ‘DEFAULT_FORMATS‘django-xadmin的安装https://blog.csdn.net/qq_52385631/article/details/122761875?spm=1001.2014.3001.5501

六:如果之前没有创建超级用户,需要创建,如果有了,则可以直接使用之前的。

python manage.py createsuperuser

七:使用

1.在应用中创建adminx.py文件(一定要叫adminx.py)

import xadmin
from xadmin import views

class BaseSetting(object):
    """xadmin的基本配置"""
    enable_themes = True  # 开启主题切换功能
    use_bootswatch = True # 引导控制盘(其实就是我们的左侧菜单栏)

xadmin.site.register(views.BaseAdminView, BaseSetting)

class GlobalSettings(object):
    """xadmin的全局配置"""
    site_title = "修脚中心"  # 设置站点标题
    site_footer = "欢迎你的到来"  # 设置站点的页脚
    menu_style = "accordion"  # 设置菜单折叠

xadmin.site.register(views.CommAdminView, GlobalSettings)

2.跟admin一样,正常注册使用即可

# 注册表模型以及相关的配置
class XConfig(object):
    list_display = ['id', 'name']

xadmin.site.register(models.Student, XConfig)

3.拓展

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',)
    #    },
    }
- title 控制图标名称
- x-field 控制x轴字段
- y-field 控制y轴字段,可以是多个值
- order 控制默认排序

model_icon** 控制菜单的图标【图标的设置可以参考font-awesome的图标css名称】
model_icon = 'fa fa-gift'

readonly_fields** 在编辑页面的只读字段
readonly_fields = ['name',]

exclude** 在编辑页面隐藏的字段,比如判断这个数据是否删除的delete_status字段,一般就是用来标识一下字段是不是被删除了,但是数据库中不删除
exclude = ['name',]

上一篇:django2.2——读写分离


下一篇:Nginx+UWSGI+Django 整合安装