首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django Admin自定义外键选择框

Django Admin是Django框架提供的一个强大的管理界面,用于管理后台数据和进行 CRUD(创建、读取、更新、删除)操作。在Django Admin中,当我们需要在模型中使用外键字段时,可以通过自定义外键选择框来提供更好的用户体验和功能定制。

自定义外键选择框可以通过以下步骤实现:

  1. 创建一个自定义的表单类(Form class),继承自Django的ModelForm类。在表单类中,我们可以定义外键字段的选择框的样式、筛选条件等。
  2. 在自定义的表单类中,通过重写外键字段的queryset属性,可以自定义外键选择框中的选项。queryset属性可以接受一个查询集(QuerySet),我们可以在其中使用过滤器、排序等方法来定制外键选择框中的选项。
  3. 在模型的Admin类中,通过重写form属性,将自定义的表单类与Admin类关联起来。这样,在Django Admin中使用该模型时,就会使用我们自定义的外键选择框。

下面是一个示例代码,演示如何在Django Admin中自定义外键选择框:

代码语言:txt
复制
from django import forms
from django.contrib import admin
from django.contrib.auth.models import User

class CustomUserForm(forms.ModelForm):
    class Meta:
        model = User
        fields = '__all__'

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        # 自定义外键选择框的queryset
        self.fields['groups'].queryset = self.fields['groups'].queryset.filter(name__startswith='Group')

class CustomUserAdmin(admin.ModelAdmin):
    form = CustomUserForm

admin.site.register(User, CustomUserAdmin)

在上述示例中,我们自定义了一个名为CustomUserForm的表单类,继承自ModelForm。在表单类中,我们重写了外键字段groups的queryset属性,将其筛选为以"Group"开头的选项。

然后,在CustomUserAdmin中,我们将form属性设置为CustomUserForm,将自定义的表单类与Admin类关联起来。这样,在Django Admin中管理User模型时,就会使用我们自定义的外键选择框。

这样的自定义外键选择框可以提供更灵活和定制化的选项,使得在Django Admin中管理外键关联数据更加方便和高效。

推荐的腾讯云相关产品:无

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Django(15)和表关系

    删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: CASCADE:级联操作。...如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。 SET_NULL:设置为空。...如果的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 SET():如果的那条数据被删除了。...注意:以上这些选项只是Django级别的,数据级别依旧是RESTRICT! 表关系 表之间的关系都是通过来进行关联的。而表之间的关系,无非就是三种关系:一对一、一对多、多对多等。...这个OneToOneField其实本质上就是一个,只不过这个有一个唯一约束(unique key),来实现一对一。 以后如果想要反向引用,那么是通过引用的模型的名字转换为小写的形式进行访问。

    2.1K40

    django admin 添加自定义链接方式

    效果展示 解决 首先在django admin的列表中查看数据id所代表的链接 ? 使用浏览器的检查元素功能查看点击该id所跳转的链接 ? 现在我们知道点击admin页面跳转链接的格式了。...id就行 return "/admin/learningsource/learningsource/" + id + "/change/" 自定义模型表单 假如我们的模型定义如下 class FeedbackModel...总结 使用这种方法可以不用创建一个空的模型然后重写它的changelist_view函数实现自定义链接,可以给admin界面的文字,图片等添加链接(通过自定义widget就可实现),并且链接样式可以自己定义...在安全性上,本文的做法实际上相当于自己手动给django admin内置视图函数发送请求,和原来django自己自动生成的页面链接没有任何区别,对自定义链接的响应实际上也要经过**django ** admin...以上这篇django admin 添加自定义链接方式就是小编分享给大家的全部内容了,希望能给大家一个参考。

    1.3K20

    django 引用自身和on_delete参数

    该模型使用引用自己本身。...如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。如果我们强行删除,Django就会报错。...、update的时候,子表会将关联记录的字段所在列设为null,所以注意在设计子表时不能设为not null; 为什么在django中可以是用不同的约束去操作数据库呢。...比如 django 中 on_delete=CASCADE, 但是数据库的约束是RESTRICT....在进行删除A表数据时,发现被约束着,使数据不能被删除,则django会先去删除约束的B表数据,然后再来删除A表数据。

    1.3K20

    Django学习-第七讲:django 中的常用字段、字段属性,和表关系、操作

    和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持约束的。的存在使得ORM框架在处理表关系的时候异常的强大。...因此这里我们首先来介绍下Django中的使用。 类定义为class ForeignKey(to,on_delete,**options)。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个,记录着对应的作者的主键。...如果一个模型使用了。...如果对应的那条数据被删除了,那么这条数据也会被删除。 2.PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。 3.SET_NULL:设置为空。

    4K30

    Django学习笔记 1.7 自定义 admin 站点

    作者: iotisan 前言 这节笔记将更加深入地处理 admin 站点,包括修改表单更加直观呈现模型数据,快速添加关联对象,以及后台涉及的列表展示、过滤器、搜索等操作。...1 自定义后台表单 polls/admin.py 通过 admin.site.register(Question) 注册 Question 模型,Django 能够构建一个默认的表单用于展示。...通常来说,你期望能自定义表单的外观和工作方式。你可以在注册模型时将这些设置告诉 Django。...from django.contrib import admin from .models import Choice, Question # ... admin.site.register(Choice...3 自定义后台更改列表 3.1 显示列表 默认情况下,Django 显示每个对象的 str() 返回的值。但有时如果我们能够显示单个字段,它会更有帮助。

    99120

    Django后台管理之Admin actions自定义

    通常情况下,admin的工作模式是“选中目标,然后修改目标”,但在同时修改大量目标的时候,这种模式就变得重复、繁琐。 为此,admin提供了自定义功能函数actions的手段,可以批量对数据进行修改。...下面以一个新闻应用的文章模型为例,介绍一个批量更新的自定义actions,它将选择的文章由“草稿”状态更新为“发布”状态: 首先是模型的代码: from django.db import models...(Article, ArticleAdmin) 然后,页面看起来是下面的样子(注意下拉): ?...处理错误: 这其中,如果你能够预知在自定义的操作中可能产生的错误,请处理该错误,并通过django.contrib.admin.ModelAdmin.message_user()以友好的方式给予用户提示信息...class MyModelAdmin(admin.ModelAdmin): actions = None 根据条件自动启用或禁用: 还可以根据条件自动选择性的启动或禁用某些acitons

    2.2K50

    django在开发中取消约束的实现

    # 在setting设置 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给关系传值...''' 两种方法 教室ClassRoom和教室编号ClassNumber 字段在django类里名(room_number)在数据库名(room_number_id) '''      # 一.1...(数据库的字段名字room_number_id)的值,将相对应的值直接赋值给该字段      class_number = ClassNumber.object.get("id=1").room_number...字段在django类里名(room_number)在数据库名(room_number_id)      c.save() return HttpResponse("ojbk") 多对一: 类似一对一...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发中取消约束就是小编分享给大家的全部内容了,希望能给大家一个参考。

    3.7K10

    如何使用 Django 更新模型字段(包括字段)

    本教程将详细介绍如何通过 Django 更新模型字段,重点讨论了解决字段更新的方法,特别是使用 attrs 方式的实现。1. 简介Django 中的模型是应用程序中管理数据的核心部分。...下面我们详细探讨这种更新方式:使用 attrs 方式更新字段在 Django 中,可以直接通过设置字段的方式来更新模型中的关联。...高级用法:使用 update() 方法批量更新字段除了直接设置字段,还可以使用 Django 的 update() 方法来批量更新查询集中的对象。...总结与实践建议在本教程中,我们深入探讨了如何使用 Django 更新模型字段,特别是处理字段更新的方法。...希望本教程能够帮助你理解和应用 Django 中模型字段更新的技巧,提升你在开发过程中的效率和数据管理能力。在实际应用中,根据具体情况选择合适的更新方法,以确保应用程序的稳定性和性能优化。6.

    21810

    django模型中有关系的表删除相关设置

    0904自我总结 django模型中有关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...related_name(detail),详情找作者用 字段(author) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.CASCADE级联删除...,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作...,models.DO_NOTHING关联无动作 三.以外字段关联 1)断关联,删除关联表记录,键值置空 db_constraint=False, on_delete=models.SET_NULL...,反向找 字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置,且一定是级联)

    3K20

    Django(ForeignKey)操作以及related_name的作用

    之前已经写过一篇关于Django的文章,但是当时并没有介绍如何根据对数据的操作,也就是如何通过主表查询子表或者通过子表查询主表的信息 首先我定义了两个模型,一个是老师模型,一个是学生模型,...: 第一步需要做的自然还是需要将我们的模型导入进来,并获取老师的相关信息 返回一个teacher对象,接下来就是查询teacher相关联的学生对象,在这里有一个需要注意的点,django...默认情况下每一个主表的对象都有一个是的属性,可以通过它查询到所有关于子表的信息,这个属性的名字就是子表的名称小写加上_set,具体到这个就是student_set,默认返回的是QuerySet,操作如下...: 在这里也会牵涉到另外一个知识点related_name的使用,在models.py使用Foreign定义的时候也可以传入一个参数related_name,操作如下: 执行python...,那么就可以通过定义时候的那个的字段名获取关于主表的信息了 比如我得到了一个student对象,然后我想要得到这个student对象对应的主表teache中的信息的话,就使用 student.teacher

    2K10
    领券