Django Admin之常用功能汇总
1.字段支持下拉搜索框
1)在admin中新增字段autocomplete_fields
autocomplete_fields = ("field1","field2")
注意:field1,field2字段需要的是外键字段
2)field1,field2字段需要在model中添加类属性search_fields
search_fields = ('name', )
注意:name为field1或field2对应表中要进行搜索的字段
2.字段支持自定义颜色选择器

1)安装python扩展
pip install django-colorfield 生成静态文件
python manage.py collectstatic
2) 配置文件settings.py , 添加配置项
在INSTALLED_APPS中添加
INSTALLED_APPS = [ ...
'colorfield',
...
]

3) 在model.py中添加字段支持
from django.db import models
from colorfield.fields import ColorField
class ComputerRoom(models.Model):
name = models.CharField(max_length=256,verbose_name = "名称")
abbr = models.CharField(max_length=128, blank=True, null=True,verbose_name = "缩写")
type = models.CharField(max_length=256,verbose_name='类型', choices=typeChoices)
color = ColorField(default='#FF0000',verbose_name='显示颜色')
然后在Django后台打开对应的模块就可以看到颜色选择器了。
3.自定义菜单
左侧可折叠菜单是Simple UI系统默认菜单,根据已注册的应用和模型自动生成,其中父级菜单是App名,子菜单一般是所属App的各个模型名。SimpleUI甚至会自动为你分配默认图标,比如本例的tasks的应用使用了font-awsome的fa fa-tasks。在大多数情况下,Simple UI系统默认菜单不能满足需求,这时你就需要自定义菜单了,比如添加新的选项或给菜单选项分配新的图标。
修改settings.py, 添加如下代码:
SIMPLEUI_CONFIG = {
# 是否使用系统默认菜单,自定义菜单时建议关闭。
'system_keep': False,
# 用于菜单排序和过滤, 不填此字段为默认排序和全部显示。空列表[] 为全部不显示.
'menu_display': ['任务管理', '权限认证'],
# 设置是否开启动态菜单, 默认为False. 如果开启, 则会在每次用户登陆时刷新展示菜单内容。
# 一般建议关闭。
'dynamic': False,
'menus': [
{
'app': 'auth',
'name': '权限认证',
'icon': 'fas fa-user-shield',
'models': [
{
'name': '用户列表',
'icon': 'fa fa-user',
'url': 'auth/user/'
},
{
'name': '用户组',
'icon': 'fa fa-th-list',
'url': 'auth/group/'
}
]
},
{
'name': '任务管理',
'icon': 'fa fa-th-list',
'models': [
{
'name': '任务列表',
# 注意url按'/admin/应用名/模型名小写/'命名。
'url': '/admin/tasks/task/',
'icon': 'fa fa-tasks'
},
]
},
]
}
自定义菜单效果如下所示。我们更改了SimpleUI默认分配的图标。你还可以随意增减菜单选项并对其进行排序:

查找相关图标:https://fontawesome.com/v5.15/icons?d=gallery&p=2
4.
一般测试环境会使用migrate来添加新的字段或者表, 但是线上一般不会使用命令直接操作,以防引起不可预知的问题, 这个时候就可以手动的将测试服的相关表变更同步到生产环境
尤其是使用的admin后台的时候, 依赖他本身的权限管理这一套, 涉及表:
django_content_type: 添加对应app_label和model记录
auth_permission: 添加对应操作项(Can add xxx,Can change xxx, Can delete xxx, Can view xxx)
5. 禁用编辑链接和添加,修改, 删除操作
在admin.py文件的具体类中 class MyModelAdmin(models.ModelAdmin):
...
List_display_links = None #禁用编辑链接 def has_add_permission(self, request):
# 禁用添加按钮
return False def has_delete_permission(self, request, obj=None):
# 禁用删除按钮
return False def has_change_permission(self, request, obj=None):
# 禁用修改按钮
return False def get_actions(self, request):
# 在actions中去掉‘删除’操作
actions = super(GradesManagementAdmin, self).get_actions(request)
if request.user.username[0].upper() != 'J':
if 'delete_selected' in actions:
del actions['delete_selected']
return actions
需要注意的是,这种禁用编辑链接的放法只是不让它在页面中显示,即把超链接去掉了,但是还是可以通过手动输入url的方式来进入编辑页面。不过可以配合设置fieldsets或者readonly_fieldss来达到目的。
6.常用设置项
1)展示模型字段
list_display= ('id', 'uid',)

2)设置隐藏信息
fieldsets = () fieldsets = (
('职业信息', {'fields': ('job','title',)}),
('人员信息', {
'classes': ('collapse',),
'fields':('person',),
})
)

3)将下拉框改成单选按钮
admin.HORIZONTAL 水平排列
admin.VERTICAL 垂直排列 radio_fields = ('person': admin.HORIZONTAL)


4).设置不可编辑字段
readonly_fields = [] readonly_fields = ['job']
5).设置升降序
ordering = [] ordering = ['id']
默认是升序,降序为 ordering = ['-id']

6).设置字段可以排序显示 sortable_by = []
sortable_by = ['job','title']

7).为字段设置路由地址,点击即进入修改页面 list_display_links=[]
list_display_links = ['id','job']

8)设置过滤器 list_filter = []
list_filter = ['job','title']

9)设置每一个的数量
设置每一页的数据量
list_per_page = 100 设置每一个的最大数据量
list_max_show_all = 200
10)设置字段可编辑 list_editable =[]
list_editable = ['title']

11)设置可搜索字段search_fields=[]
search_fields = ['job']

12)修改/admin页面的index的title
在APP文件下的__init__.py


13)修改中文字段中多处的‘s’
models.py中添加verbose_name_plural

14)后台文字描述修改
后台网页title修改
APP下的urls.py 最后添加
admin.site.site_title = '后台标题'
admin.site.site_header = '后台头部'
admin.site.index_title = '后台首页标题'


7, 文件上传并支持将docx文档内容转化为HTML
配置文件添加媒体路径:
MEDIA_ROOT = os.path.join(BASE_DIR, "uploads")
目录结构:

models.py
from django.db import models from django.core import validators
from tinymce.models import HTMLField
from colorfield.fields import ColorField class UserAgreement(models.Model):
AGREE_TYPES = (
(1, '收集个人信息'),
(2, '共享个人信息'),
(3, '隐私协议'),
(4, '服务协议'),
)
appid = models.ForeignKey(Game, db_column='appid', null=True, default=0, on_delete=models.SET_NULL,
verbose_name='游戏')
type = models.IntegerField(default=0, choices=AGREE_TYPES, blank=True, verbose_name='类型')
content = HTMLField('内容')
background_color = ColorField(max_length=32, null=True, default='#fef9db', verbose_name='背景色')
upload_file = models.FileField(upload_to='', null=False, default='', validators=[
validators.FileExtensionValidator(['docx', 'doc', 'pdf'], message='请上传正确格式的文件')
], verbose_name='上传文件', help_text='支持上传的文件格式:pdf,doc,docx')
search_fields = ('appid',) def __str__(self):
return self.content class Meta:
db_table = "user_agreement"
verbose_name = verbose_name_plural = "用户相关协议表"
安装docx转换HTML包pydocx
pip install pydocx
admin.php 文件
from django.contrib import admin
from .models import * @admin.register(UserAgreement)
class UserAgreementAdmin(admin.ModelAdmin):
list_display = ('appid', 'type', 'content', 'background_color')
list_filter = ('appid',)
list_per_page = 10 autocomplete_fields = ('appid', ) def save_model(self, request, obj, form, change):
file = request.FILES.get('upload_file')
if file:
html = PyDocX.to_html(file)
obj.content = html
cache_key = RedisKey.USER_AGREEMENT.format(obj.appid_id, obj.type)
delete_cache(cache_key)
super().save_model(request, obj, form, change)
展示效果:

参考:Django实战: 手把手教你配置Django SimpleUI打造美丽后台(多图) - 知乎 (zhihu.com)
Django Admin之常用功能汇总的更多相关文章
- Hbuilder常用功能汇总
引用 样式表: mui.min.css Js:mui.min.js 常用功能 获取页面 var webView=plus.webview.currentWebview();//获取当前页 var we ...
- Django admin自定制功能
一:基础设置 1.应用注册 1)方式一 若要把app应用显示在后台管理中,需要在admin.py中注册.打开admin.py文件,如下代码: from django.contrib import ad ...
- Django Admin后台管理功能使用+二次开发
一 使用环境 开发系统: windows IDE: pycharm 数据库: msyql,navicat 编程语言: python3.7 (Windows x86-64 executable in ...
- Python菜鸟之路:Django Admin后台管理功能使用
前言 用过Django框架的童鞋肯定都知道,在创建完Django项目后,每个app下,都会有一个urls.py文件,里边会有如下几行: from django.contrib import admin ...
- django admin后台管理功能的学习
1.简要说明 用过Django框架的童鞋肯定都知道,在创建完Django项目后,每个app下,都会有一个urls.py文件,里边会有如下几行: from django.contrib import a ...
- Django Admin后台管理功能使用
前言 用过Django框架的童鞋肯定都知道,在创建完Django项目后,每个app下,都会有一个urls.py文件,里边会有如下几行: 1 2 3 4 5 from django.contrib im ...
- Django框架ORM常用字段汇总_模型层
与数据类型相关的字段 CharField 作用:字符串字段, 用于较短的字符串. 参数:CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许 ...
- Idea 常用功能汇总,工作中常用技巧
1.隐藏没用到的文件 比如 IDEA 的项目配置文件(.iml 和.idea),打开 Settings-File Types, 加入要隐藏的文件后缀. 2.常用技巧 2.1 通过Alt+F8查看变量 ...
- Idea 常用功能汇总,工作中常用技巧,移出请说明原因,笔记花了好长时间汇总的
1.隐藏没用到的文件 比如 IDEA 的项目配置文件(.iml 和.idea),打开 Settings-File Types, 加入要隐藏的文件后缀. 2.常用技巧 2.1 通过Alt+F8查看变量 ...
- Django框架ORM常用参数汇总_模型层
primary_key 如果为True,那么这个字段就是模型的主键. 如果你没有指定任何一个字段的primary_key=True, Django就会自动添加一个IntegerField字段做为主键, ...
随机推荐
- C++创建与调用dll动态链接库(MinGW64 Dev-C++)
本文使用的是dev-c++,如果涉及到VC++中不一样的操作,也会适当进行区分. 项目一:创建DLL 1.创建一个DLL类型的项目,当前命名为dlltest,并选择合适的路径进行保存. 2.在生成的 ...
- Redis常见问题和性能监控
1 Redis常见面试问题 1.1 Redis是单线程还是多线程 Redis不同版本之间采用的线程模型是不一样的,在Redis4.0版本之前使用的是单线程模型,在4.0版本之后增加了多线程的支持. 在 ...
- ASP.NET Core – Swagger API Versioning
前言 Versioning 会导致 Swagger 直接坏掉. 因为 1 个文档无法支持多个版本. 所以需要每一个版本做一个文档. 主要参考 Integrating ASP.NET Core Api ...
- 浅谈舞蹈链(DLX)
名字: \(DL\),\(Dancing\space Link\),舞蹈链,是由\(Donald\space Knuth\)提出的数据结构,用来优化 \(X\) 算法,所以叫\(DLX\) \(X\) ...
- [Tkey] 与非
解法原理1 首先我们需要明白 \(\operatorname{nand}\) 的运算: \[\operatorname{not}(a\operatorname{nand}b)=a\operatorna ...
- iOS上架App Store使用小结
1.安装iOS上架辅助软件Appuploader 2.申请iOS发布证书(p12) 3.申请iOS发布描述文件(mobileprovision) 4.打包ipa 5.上传ipa到iTunes Conn ...
- kotlin关键字与操作符
硬关键字:始终解释为关键字,不能用作标识符 as - 用于类型转换 - 为导入指定一个别名 as? 用于安全类型转换 break 终止循环的执行 class 声明一个类 continue 继续最近层循 ...
- .NET使用Graphql的演示
Graphql是什么?先来一段AI给的回答: GraphQL是一种为API设计的查询语言,与REST相比,它提供了更高效.强大和灵活的方法来与数据交互.GraphQL由Facebook于2012年开发 ...
- 什么是前后端分离应用(Full-stack Separation),想当然就会理解错
前后端分离应用指的是将应用的前端部分(用户界面与交互逻辑)和后端部分(业务逻辑.数据处理.服务器响应)拆分成独立的模块,各自通过 API 进行通信.这种架构设计的目的是提高开发效率.增强可扩展性和灵活 ...
- 云原生周刊:CNCF 宣布 KubeEdge 毕业
云原生周刊:CNCF 宣布 KubeEdge 毕业 开源项目推荐 Watchtower Watchtower 这个项目能够自动监测并更新正在运行的 Docker 容器.它会定期检查并拉取 Docker ...