Django Form 实现多层(嵌套)模型表单

在 Django 中,可以通过使用 ModelFormInlineFormSet 来实现多层(嵌套)模型表单。这样可以在一个表单中同时编辑主模型及其相关的子模型。下面是一个示例,演示如何实现这种多层嵌套的表单。

在这里插入图片描述

1、问题背景

  • 如何使用 Django 的 Form 来创建涉及多个模型的多层嵌套表单?
  • 在 Django 初学者使用 Form 时遇到了错误“invalid literal for int() with base 10: ‘test’”。
  • 需要创建涉及多个模型的表单,例如“测验-问题-答案”模型,并且每个测验包含多个问题,每个问题有多个答案。

2、解决方案

  • 方法一
    • 使用 Django 的 ModelForm 来创建各个模型的表单。
    • 手动将这些表单组合成一个多层表单。
    • 需要考虑保存数据的顺序,即先保存最底层的模型,然后是中间层的模型,最后是顶层的模型。
  • 方法二
    • 使用 Django 的 InlineFormSetModelForm 来创建多层表单。
    • InlineFormSet 可以用来创建嵌套的表单集,其中每个表单集对应一个模型。
    • ModelForm 可以用来创建单个模型的表单。
    • 将这些表单集和表单组合在一起,就可以生成一个多层表单。

代码示例

方法一:手动组合表单

from django.forms import ModelForm, Formclass QuizForm(ModelForm):class Meta:model = Quizclass QuestionForm(ModelForm):class Meta:model = Questionclass AnswerForm(ModelForm):class Meta:model = Answerclass MultiLayerForm(Form):quiz_form = QuizForm()question_forms = QuestionFormSet(queryset=Question.objects.filter(quiz=None))answer_forms = AnswerFormSet(queryset=Answer.objects.filter(question=None))def view_function(request):if request.method == 'POST':quiz_form = QuizForm(request.POST)question_forms = QuestionFormSet(request.POST, queryset=Question.objects.filter(quiz=None))answer_forms = AnswerFormSet(request.POST, queryset=Answer.objects.filter(question=None))if quiz_form.is_valid() and all(form.is_valid() for form in question_forms) and all(form.is_valid() for form in answer_forms):# Save the formsquiz = quiz_form.save()for question_form in question_forms:question = question_form.save(commit=False)question.quiz = quizquestion.save()for answer_form in answer_forms:answer = answer_form.save(commit=False)answer.question = questionanswer.save()return HttpResponseRedirect('/')else:quiz_form = QuizForm()question_forms = QuestionFormSet(queryset=Question.objects.filter(quiz=None))answer_forms = AnswerFormSet(queryset=Answer.objects.filter(question=None))return render(request, 'form.html', {'quiz_form': quiz_form, 'question_forms': question_forms, 'answer_forms': answer_forms})

方法二:使用 InlineFormSetModelForm

from django.forms import ModelForm, inlineformset_factoryclass QuizForm(ModelForm):class Meta:model = QuizQuestionFormSet = inlineformset_factory(Quiz, Question, fields=('label',))
AnswerFormSet = inlineformset_factory(Question, Answer, fields=('label', 'correct'))def view_function(request):if request.method == 'POST':quiz_form = QuizForm(request.POST)question_forms = QuestionFormSet(request.POST, instance=quiz_form.instance)answer_forms = AnswerFormSet(request.POST, instance=question_forms.instance)if quiz_form.is_valid() and all(form.is_valid() for form in question_forms) and all(form.is_valid() for form in answer_forms):# Save the formsquiz = quiz_form.save()question_forms.save()answer_forms.save()return HttpResponseRedirect('/')else:quiz_form = QuizForm()question_forms = QuestionFormSet(instance=quiz_form.instance)answer_forms = AnswerFormSet(instance=question_forms.instance)return render(request, 'form.html', {'quiz_form': quiz_form, 'question_forms': question_forms, 'answer_forms': answer_forms})

通过上述步骤,你可以创建一个嵌套的表单界面,使得用户可以在同一页面上输入主模型及其相关子模型的信息。这种方法非常适合需要处理多层数据结构的应用场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/59004.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux - grep的正则用法

新建u.txt,文本内容如图: 搜寻特定字符串 利用中括号[]搜寻集合字符 行首与行位字符^$ 任意一个字符.与重复字符*限定连续RE字符范围{} 总结:

落地灯选什么光源最好?五款值得入手的大路灯护眼灯推荐

落地灯选什么光源最好?落地灯是既适合日常人群使用,又适合长时间用眼的学生党、码字党使用的一种照明神器,因此热度一直都很高。但是该行业内的产品也很复杂,其中还有一些劣质不专业的产品掺杂在其中,不但灯光效果不明…

windows C#-类型系统(下)

引用类型 定义为 class、record、delegate、数组或 interface 的类型是 reference type。 在声明变量 reference type 时,它将包含值 null,直到你将其分配给该类型的实例,或者使用 new 运算符创建一个。 下面的示例演示了如何创建和分配类&…

‌Vue 3相比Vue 2的主要改进‌?

‌Vue 3相比Vue 2的主要改进‌ ‌‌Composition API‌:Vue 3引入了Composition API,允许以更灵活和可复用的方式组织组件逻辑。‌响应式系统‌:使用‌Proxy实现响应式系统,相比Vue 2的Object.defineProperty,性能有显…

如何获取免费的纯真社区版IP库授权?

纯真社区版IP库 1、访问官网 https://cz88.net/geo-public 地址注册账号 2、登录账号后,申请api 授权

【AAOS】【源码分析】CarSystemUI -- CarSystemBar

CarSystemBar不像Android手机那样固定的顶部“状态栏”和底部“导航栏”,而是将StatusBar和NavigationBar都统称为SystemBar,可以通过如下配置为每侧最多配置一个“系统栏”。 packages/apps/Car/SystemUI/res/values/config.xml<!-- Configure which system bars should …

深度学习揭秘:神经网络如何模拟人脑

大家好&#xff0c;我是Shelly&#xff0c;一个专注于输出AI工具和科技前沿内容的AI应用教练&#xff0c;体验过300款以上的AI应用工具。关注科技及大模型领域对社会的影响10年。关注我一起驾驭AI工具&#xff0c;拥抱AI时代的到来。 AI工具集1&#xff1a;大厂AI工具【共23款…

MySQL表转移数据的三种方式

说明&#xff1a;在一些情况&#xff0c;像大表修改表结构&#xff0c;重新建立分区&#xff08;对已有表建立分区&#xff0c;对历史数据是不生效的&#xff09;&#xff0c;或者表备份&#xff0c;我们需要将表的数据&#xff0c;从一张表转移到另外一张表里。本文介绍&#…

C++中,`::`、`->` 和 `.`

C中&#xff0c;::、-> 和 . 在C中&#xff0c;::、-> 和 . 是用于访问成员&#xff08;如变量、函数等&#xff09;的不同操作符&#xff0c;它们分别用于不同的场景。以下是它们各自的作用和用法&#xff1a; 双冒号 :: (作用域解析操作符) 用于指定某个标识符&#x…

【DBeaver】连接带kerberos的hive[Apache|HDP]

目录 一、安装配置Kerberos客户端环境 1.1 安装Kerberos客户端 1.2 环境配置 二、基于Cloudera驱动创建连接 三、基于Hive原生驱动创建连接 一、安装配置Kerberos客户端环境 1.1 安装Kerberos客户端 在Kerberos官网下载,地址如下&#xff1a;https://web.mit.edu/kerberos…

总结一些高级的SQL技巧

1. 窗口函数 窗函数允许在查询结果的每一行上进行计算&#xff0c;而不需要将数据分组。这使得我们可以计算累积总和、排名等。 SELECT employee_id,salary,RANK() OVER (ORDER BY salary DESC) AS salary_rank FROM employees;2. 公用表表达式 (CTE) CTE 提供了一种更清晰的…

1.探索WebSocket:实时网络的心跳!

序言 你可能听说过"WebSokcet"这个词&#xff0c;感觉它好像很高深&#xff0c;但其实它是一个超级酷的小工具&#xff0c;让我们在Web应用里实现实时通信。想象一下&#xff0c;你可以像聊天一样&#xff0c;在浏览器和服务器之间来回“畅聊“&#xff0c;没有延迟…

芋道前端Vue项目中的配置文件

1.Vite配置相关文件 vite.config.ts build\vite\optimize.ts build\vite\index.ts package.json package-lock.json pnpm-lock.yaml types文件 types\router.d.ts types\global.d.ts types\env.d.ts types\custom-types.d.ts types\components.d.ts 环境配置 .env.test .e…

【大数据学习 | kafka】kafka的数据存储结构

以上是kafka的数据的存储方式。 这些数据可以在服务器集群上对应的文件夹中查看到。 [hexuanhadoop106 __consumer_offsets-0]$ ll 总用量 8 -rw-rw-r--. 1 hexuan hexuan 10485760 10月 28 22:21 00000000000000000000.index -rw-rw-r--. 1 hexuan hexuan 0 10月 28 …

做一个干电池的电量检测器03:数值拟合与电路仿真

首先在表格中进行详细的计算&#xff0c;整理出所需的数据。接着&#xff0c;我们运用MATLAB的强大功能对这些数据进行插值处理&#xff0c;生成了一个离散的数值数组。这个数组的每个数值都精确地对应着模数转换器&#xff08;ADC&#xff09;采样到的信号。通过这些数值&…

1、Java概述、HelloWorld案例

文章目录 今日内容介绍1.1 Java语言发展史和平台概述1.1.1 Java语言发展史1.1.2 Java语言版本1.1.3 Java平台概述1.2 JVM, JRE, JDK概述1.2.1 什么是跨平台?1.2.2 JVM, JRE, JDK说明1.3 常用DOS命令1.3.1 打开控制台1.3.2 常用命令1.4 下载安装JDK1.5 HelloWorld案例1.5.1 执行…

MFC工控项目实例二十八模拟量信号每秒采集100次

用两个多媒体定时器&#xff0c;一个定时0.1秒计时&#xff0c;另一个定时0.01秒用来对模拟量信号采集每秒100次。 1、在SEAL_PRESSUREDlg.h中添加代码 class CSEAL_PRESSUREDlg : public CDialo { public:CSEAL_PRESSUREDlg(CWnd* pParent NULL); // standard constructor&a…

【Mac】Screen Recorder by Omi Mac:Omi录屏专家

大家好&#xff0c;今天给大家介绍的这款软件叫Screen Recorder by Omi Mac&#xff1a;Omi录屏专家。 软件介绍 OmniRecorder for Mac 是一款用于录制屏幕的应用程序&#xff0c;专为 macOS 设计。它允许用户录制整个屏幕或特定区域&#xff0c;支持音频录制和实时编辑。这个…

多波束T50P和SES2000 Medium100安装记录(2024年10月)

SES2000 Medium100买了一直没有机会用&#xff0c;本次外业刚好需要。SES2000最大穿透70m。 Medium100安装与SES2000 Standard基本相同。除了钢管和法兰不同以外&#xff0c;它们安装支架都可以通用。有条件的话&#xff0c;用焊接方式将其固定在船侧舷&#xff0c;前方加一道拉…

Nginx安装配置详解

Nginx Nginx官网 Tengine翻译的Nginx中文文档 轻量级的Web服务器&#xff0c;主要有反向代理、负载均衡的功能。 能够支撑5万的并发量&#xff0c;运行时内存和CPU占用低&#xff0c;配置简单&#xff0c;运行稳定。 写在前 uWSGI与Nginx的关系 1. 安装 Windows 官网 Stabl…