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名字

相关推荐
阿波罗尼亚7 小时前
数据库序列(Sequence)
数据库
Mr数据杨7 小时前
【Codex】用Tauri用户配置打通桌面端个性化设置
django·codex·项目开发
Junsir大斗师7 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish7 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
百锦再8 小时前
Auto.js变成基础知识学习
开发语言·javascript·学习·sqlite·kotlin·android studio·数据库开发
m0_596749099 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
Mr数据杨9 小时前
【Codex】用整合教案模块串联PPT文案与课堂教学方案
django·powerpoint·codex·项目开发
Mr数据杨9 小时前
【Codex】用教案主体模块沉淀标准化教学设计内容
java·开发语言·django·codex·项目开发
老纪的技术唠嗑局10 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
2301_7950997412 小时前
golang如何在Gin中自定义验证器_golang Gin自定义验证器实现方法
jvm·数据库·python