侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

详解Django admin高级用法

框架(架构)  /  管理员 发布于 7年前   327

使用Django意味着后台框架的几乎所有内容都会和Django产生互动,排除功能全部手撸的情况.

Django 后台admin有大量的属性和方法,拥有强大的功能和自定义能力.通过完整的代码来看Django admin的基础设置和高级用法,并结合form表单来实现深度自定义.

简单使用

如果只是使用admin自带的数据管理功能,只需要将模型注册到admin中,就可以实现.

from django.contrib import adminadmin.site.register(News)admin.site.register(NewsType)admin.site.site_header = "数据库"admin.site.index_title = "新闻后台"

Django后台会将对应数据表的所有字段进行展示,默认点击 id 会进入修改页面,对应 change_form.html 模板.

自定义admin类

使用admin也可以自定义一个admin的类,来自定义后台实现的属性和方法,然后通过 register() 来将自定义的类和模型注册在一起.

注册方式有两种,一种是使用类装饰器,一种是使用 site

from django.contrib import admin# 装饰器注册@admin.register(ModelClass)class CustomAdmin(admin.ModelAdmin):  list_display = '__all__'# 使用siteclass CustomAdmin(admin.ModelAdmin):  exclude = ['id']admin.site.register(CustomAdmin, ModelClass)

admin显示属性的设置

ModelAdmin中的属性设置

admin可以设置在列表页和详情页显示的字段以及搜索字段等的限制,在admin的类中可以直接定义.

以使用较多的 ModelAdmin 为例, ModelAdmin 源码中的属性有:

# 在列表页显示的字段,默认会显示所有字段,有对应的方法可以重写list_display = ('__str__',)# 在列表页显示的字段中,可以链接到change_form页面的字段list_display_links = ()# 右侧的筛选,必须是字段,可以继承自SimpleListFilter来自定义筛选字段和规则,SimpleListFilter的方法在后面详细介绍list_filter = ()# 联表查询是否自动查询,可以是布尔,列表或元组,如果是列表或元组,则级联查询指定的字段list_select_related = False# 列表页每页展示的条数list_per_page = 100# 分页,显示全部,真是数据小于该值时才会显示全部list_max_show_all = 200# 在列表页可以编辑的字段list_editable = ()# 在列表页可以模糊搜索的字段search_fields = ()# 对Date和DateTime类型进行搜索date_hierarchy = None# 在change_form页面,按钮为,save按钮的值(save as new和save add another)save_as = False# 点击保存并继续编辑save_as_continue = True# save按钮的位置,是True则显示在页面上方save_on_top = False# 自定义分页类paginator = Paginator# 详细页面,删除、修改,更新后跳转回列表后,是否保留原搜索条件管理员现在在创建,编辑或删除对象后保留列表视图中的过滤器。# 可以将此属性设置为False,以恢复之前清除过滤器的行为。preserve_filters = True# 在详情页面,如果有FK到其他表,在详情页中可以动态的填加或删除级联数据inlines = []admin中action操作的设置admin中的action是指在列表页的动作,默认为删除所选的条目,可以自定义填加动作,将动作注册到action中,需要是一个方法# 定制action中的操作actions = []action_form = helpers.ActionForm# action选项显示的位置,页面上方或者页面下方actions_on_top = Trueactions_on_bottom = False# 是否显示action选择的个数actions_selection_counter = Truechecks_class = ModelAdminChecksBaseModelAdmin中的属性除了ModelAdmin中的属性,也可以自定义在其父类BaseModelAdmin中的属性和方法,是一些通用的,在继承子BaseModelAdmin的类中也可以完成的属性设置.一般是详情页的属性.# 自动补全,外键查询数据多时,方便查找autocomplete_fields = ()# 详情页,针对外键和M2M字段变成input框形式raw_id_fields = ()# 详情页面展示的字段fields = None# 详情页面排除的字段,字段可以是数据库中的也可以是自定义的exclude = None# 在详情页面对数据进行分隔显示,对应到admin模板中的'fieldsets.html'fieldsets = None# 为详情页指定form表单,可以自定义显示的数据,字段form = forms.ModelForm# 下面两个是M2M显示时,数据移动选择.可以参考admin中用户的权限操作filter_vertical = () # 纵向展示filter_horizontal = () # 横向展示# 详情页面使用radio显示选项,FK默认使用selectradio_fields = {}# 填加页面,在某字段输入值后,自动填加到指定字段# prepopulated_fields = {"email": ("user",)},email字段会在用户填加user字段时自动填充prepopulated_fields = {}# 详情页指定显示的插件,后面详细说明formfield_overrides = {}# 详情页面的只读字段readonly_fields = ()# 详情页面排序规则ordering = None# 禁止某些排序,为空则禁止所有的排序sortable_by = None# 编辑时是否在页面上显示view on set,可以通过方法来返回一个链接,后面说明view_on_site = True# 列表页,模糊搜索后面显示的数据个数样式# 为True是显示条数,为False时显示全部show_full_result_count = Truechecks_class = BaseModelAdminChecks

模板的定制

指定自定义模板

在ModelAdmin中自带了几个指定模板的属性,可以自己定义HTML文件,来指定给某个模板页面

# Custom templates (designed to be over-ridden in subclasses)# 添加数据模板页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

重写自带模板

在django admin里面有自己写好的模板,include模板,每个app也有对应的模板

admin的自带模板在项目的 django/contrib/admin/templates/admin ,目录下面

include 文目录下是 include 语法包含的模板。

change_form.html 是数据修改页面的模板,如果想在数据详情页面自定义显示的内容,可以自定义这个页面

模板使用的全都是模板语法,注意模板语法的继承机制,在当前页面重写的元素,不会直接显示。

fieldset.htlm 是拼接成详情页的块。前面提到,自定义admin类中的 fieldset 属性,可以自定义详情页,使数据字段分块显示,就是改变了传给这个页面的值。

例如,使用 if 语句来动态添加jQuery和 div 标签,只有在访问某个app的数据时添加

{% if app_name in request.path %}  <script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-2.1.4.min.js"></script><div><fieldset class="custom"><div id="div"></div></fieldset>{% endif %}

结合form表单

django admin结合form表单,重写 fieldset.html 来实现数据详情页面的深度自定义,通过处理form表单提交的数据,来实现后台功能的完全自定义。

django的admin中可以指定form类,来自定义显示的内容

from django import forms# TagValueManager是自定义的类from tag_manager import TagValueManagerclass CustomAddForm(forms.ModelForm):  """ 根据标签的id,动态生成下拉选项框 """  for i in TagValueManager.all_tag:    locals()[      'field_tag_id_{}'.format(        i['id'])] = forms.ChoiceField(      choices=TagValueManager.get_choice(        i['id']),      label=i['name'])  class Meta:    model = CandidateTag    fields = '__all__'    exclude = ['tag_id', 'tag_value', 'ext_1', 'ext_2', 'candidate_id']

注意:在form表单中动态生成的属性,必须使用 fields='__all__‘ 属性,否则不会显示,可以结合 exclude 属性来控制需要显示的表单

然后在admin中注册form类

class CandidateTagAdmin(admin.ModelAdmin):  list_display = [    'id',    'tag_count',  ]  form = CustomAddForm

自定义列表页来源

除了可以通过修改admin的属性,来实现列表页展示字段的自定义,也可以对列表页数据进行筛选,例如,筛选出活跃的用户等,这个可以在 action 中定义新的方法

也可以重写admin中的 get_queryset 方法,返回的qs是重新筛选之后的数据,可以避免一些业务逻辑上的误操作

这里的代码展示了,在列表页,展示其他表中的数据,注册模型表的数据没有展示

def get_queryset(self, request):    """    从candidate表中查询数据,在list_display中统计其标签个数    """    qs = Candidate.objects.all().order_by('id')    return qs## 处理form数据

给admin类定义form属性之后,在详情页面传回的数据,会带上form表单里面的数据,然后结合业务逻辑处理这个数据

例如,业务场景,接受form数据,保存到其他几张表,对于展示数据的表,不进行任何操作,那就需要重写 save_model 方法,这个方法调用了模型的 save 方法

重写这个方法:

def save_model(self, request, obj, form, change):    """    重写save_model方法    """    candidate_id = request.path.split('/')[4]    post_dict = request.POST    # 根据返回的form表单的标签来确定修改的tag_id    include_field = 'field_tag_id_'    for key, value in post_dict.items():      if include_field in key:        tag_id = key.split('_')[-1]        tag_value = value        try:          obj, created = CandidateTag.objects.update_or_create(defaults={'tag_value': tag_value}, candidate_id=candidate_id, tag_id=tag_id)        except Exception as e:          tag_name = TagValueManager.all_tag.get(id=tag_id)['name']          messages.add_message(request, messages.ERROR, '求职者的"{}"标签信息保存失败'.format(tag_name))

扩展

在 get_queryset 方法中,展示类模型中的统计数据,这个统计数据,不是在数据库中生成的,实在模型类中定义的方法,这个方法的返回值,可以在列表页中直接展示。例如上文中说道的标签的个数

同时,也可以返回一个HTML标签,模板语法中获取这个字段时,得到的是一个HTML标签,直接渲染

from django.utils.safestring import mark_safe# 使用mark_safe@mark_safedef get_user_dept(self,obj):  """ 这个方法在模型中 """  return "<p>this is a HTML tag</p>"# 允许HTML标签get_report_depts.allow_tags = True# HTML展示时的字段名get_report_depts.short_description = '所属部门'

总结

以上所述是小编给大家介绍的Django admin高级用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!


  • 上一条:
    Django 简单实现分页与搜索功能的示例代码
    下一条:
    Django 请求Request的具体使用方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Filament v3.1版本发布(0个评论)
    • docker + gitea搭建一个git服务器流程步骤(0个评论)
    • websocket的三种架构方式使用优缺点浅析(0个评论)
    • ubuntu20.4系统中宿主机安装nginx服务,docker容器中安装php8.2实现运行laravel10框架网站(0个评论)
    • phpstudy_pro(小皮面板)中安装最新php8.2.9版本流程步骤(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2018-05
    • 2020-02
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-11
    • 2021-03
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-08
    • 2023-08
    • 2023-10
    • 2023-12
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客