Django admin管理工具TabularInline表格内联

详解

TabularInline 是 Django Admin 中的一个内联模型选项,用于在父模型的编辑页面中以表格形式显示关联的子模型对象。下面是对 TabularInline 的一些详解:

  1. 显示方式TabularInline 以表格的形式显示子模型对象。每个子模型对象将以一行的形式展示,显示相关字段的值。

  2. 编辑和新增 :通过 TabularInline,您可以在父模型的编辑页面中同时编辑和新增与之关联的子模型对象。您可以通过表格的行来编辑现有子模型对象,也可以通过表格底部的空白行来新增新的子模型对象。

  3. 嵌套显示 :如果在子模型中还有其他的外键关联模型,您可以使用嵌套的 TabularInline 来进一步显示和编辑这些关联的模型对象。

  4. 指定数量 :您可以通过设置 extra 属性来指定要显示的初始表格行数。

下面是一个示例,演示如何使用 TabularInline 来在 Django Admin 中显示和编辑关联的子模型对象:

python 复制代码
from django.contrib import admin
from .models import ParentModel, ChildModel

class ChildModelInline(admin.TabularInline):
    model = ChildModel

class ParentModelAdmin(admin.ModelAdmin):
    inlines = [ChildModelInline]

admin.site.register(ParentModel, ParentModelAdmin)

在上述示例中,我们定义了一个名为 ChildModelInlineTabularInline 类,并将它添加到 ParentModelAdmininlines 属性中。这样,当在 Django Admin 后台编辑 ParentModel 对象时,将在同一个页面上显示和编辑相关的多个 ChildModel

通过使用 TabularInline,您可以更方便地在 Django Admin 中管理父子模型之间的关系,提供了更直观和高效的界面来处理关联对象的增删改查操作。

案例

models.py

一个name 对应多个access_key_id

py 复制代码
class Name(models.Model):
    name = models.CharField(max_length=100)
    # 其他字段...
    class Meta:
        verbose_name = "名字"
        verbose_name_plural = "名字"

    def __str__(self):
        return self.name

class AccessKey(models.Model):
    access_key_id = models.CharField(max_length=50)
    name = models.ForeignKey(Name, on_delete=models.CASCADE)
    # 其他字段...
    class Meta:
        verbose_name = "密钥ID"
        verbose_name_plural = "密钥ID"

    def __str__(self):
        return self.access_key_id

admin.py

py 复制代码
from .models import Name,AccessKey

class AccessKeyInline(admin.TabularInline):
    model = AccessKey

class NameAdmin(admin.ModelAdmin):
    inlines = [AccessKeyInline]
    
admin.site.register(Name, NameAdmin)
admin.site.register(AccessKey)

最终效果如下

一个name可以对应多个key id

一个key只对应一个name名字

相关推荐
小爬虫程序猿3 分钟前
如何利用Python解析API返回的数据结构?
数据结构·数据库·python
wowocpp1 小时前
查看 磁盘文件系统格式 linux ubuntu blkid ext4
linux·数据库·ubuntu
Ai 编码助手7 小时前
MySQL中distinct与group by之间的性能进行比较
数据库·mysql
陈燚_重生之又为程序员7 小时前
基于梧桐数据库的实时数据分析解决方案
数据库·数据挖掘·数据分析
caridle7 小时前
教程:使用 InterBase Express 访问数据库(五):TIBTransaction
java·数据库·express
白云如幻7 小时前
MySQL排序查询
数据库·mysql
萧鼎7 小时前
Python并发编程库:Asyncio的异步编程实战
开发语言·数据库·python·异步
^velpro^7 小时前
数据库连接池的创建
java·开发语言·数据库
荒川之神7 小时前
ORACLE _11G_R2_ASM 常用命令
数据库·oracle
IT培训中心-竺老师7 小时前
Oracle 23AI创建示例库
数据库·oracle