如何在一个 HTML 结构中正确提交两个表单?

发布于 2025-01-11 09:42:51 字数 1800 浏览 0 评论 0原文

我正在尝试提交具有两种表单的创建视图。如果所有内容都已填写并已提交,下面的代码就可以正常工作。但是,如果 form2 中省略了字段...则表单提交失败,并且为“表单”...“名称”...填写的字段将被重置。我读过你可以做多种形式,我基本上已经完成了这项工作...我只需要弄清楚如何将 form2 合并到 if_valid() 中...这是我的观点...

def tasklist_detail_view(request, id):
    context = {}
    context["tasklist"] = TaskList.objects.get(id=id)
    context["tasks"] = Task.objects.filter(task_list=id).all()

    obj = get_object_or_404(TaskList, id=id)
    form = UpdateTaskListForm(request.POST or None, instance=obj)
    form2 = TaskForm(request.POST or None)
    context["task_list_id"] = id

    if form.is_valid():
        form.save()
        return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

    context["form"] = form
    context["form2"] = form2

    return render(request, "my_task_list_tasklist_detail.html", context)

我的 HTML...

<form method="POST" enctype="multipart/form-data" id="forms">
 {% csrf_token %}
 
   {{ form.name }}
       
   {% include "my_task_list_task_create_form1.html" with tasklist=tasklist %}
  
   <button type="submit" class="button66" name="status" value="Submitted">Submit</button>
    
 </form>

然后在我的包含 HTML 中...

<div id="task-list-form" hx-target="this" hx-swap="outerHTML">    
        
<button class="button35" hx-post="{% url 'MyTaskLists:task-create' id=task_list_id %}">Save</button>
               
    {{ form2 }}
               

我确实尝试做类似的事情...

if form.is_valid() and form2.is_valid():
    form.save()
    return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

但是然后没有任何反应...即使字段填写正确,表单也根本不被接受...根据我的说法已读过,我了解 POST 已应用于两种表单......如果其中一个未正确填写,这就是另一个的原因出错了?我只是不太清楚如何正确处理它们。

预先感谢您的任何想法。

I am trying to submit a create view with two forms. The code below works fine if everything is filled out and the form submitted. However if fields are omitted in form2...the form submission fails and the field that was filled out for "form"..."name"....gets reset. I've read you can do multiple forms and I've largely got this working...I just need to figure out how to incorporate form2 into the if_valid().... Here's my view...

def tasklist_detail_view(request, id):
    context = {}
    context["tasklist"] = TaskList.objects.get(id=id)
    context["tasks"] = Task.objects.filter(task_list=id).all()

    obj = get_object_or_404(TaskList, id=id)
    form = UpdateTaskListForm(request.POST or None, instance=obj)
    form2 = TaskForm(request.POST or None)
    context["task_list_id"] = id

    if form.is_valid():
        form.save()
        return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

    context["form"] = form
    context["form2"] = form2

    return render(request, "my_task_list_tasklist_detail.html", context)

My HTML...

<form method="POST" enctype="multipart/form-data" id="forms">
 {% csrf_token %}
 
   {{ form.name }}
       
   {% include "my_task_list_task_create_form1.html" with tasklist=tasklist %}
  
   <button type="submit" class="button66" name="status" value="Submitted">Submit</button>
    
 </form>

And then in my include HTML...

<div id="task-list-form" hx-target="this" hx-swap="outerHTML">    
        
<button class="button35" hx-post="{% url 'MyTaskLists:task-create' id=task_list_id %}">Save</button>
               
    {{ form2 }}
               

I did try to do something like....

if form.is_valid() and form2.is_valid():
    form.save()
    return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

But then nothing happens...the forms are not accepted at all even if the fields are filled out properly....From what I've read I understand the POST is being applied to both forms....if one is not filled out properly that is why the other errors out? I just can't quite figure out how to process them both properly.

Thanks in advance for any thoughts.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

寄意 2025-01-18 09:42:51

如果您希望两个表单表现得像一个表单,并且仅当两个表单都有效时才保存两个对象,那么逻辑是

if form.is_valid() and form2.is_valid():
    form.save()
    form2.save()
    return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

context["form"] = form
context["form2"] = form2
return render(request, "my_task_list_tasklist_detail.html", context)

如果 formform2 中存在任何同名字段 您需要使用前缀来消除歧义。

form = UpdateTaskListForm(request.POST or None, instance=obj, prefix='form1')
form2 = TaskForm(request.POST or None, prefix='form2')

If you want the two forms to behave like one form, and save two objects only if both forms are valid, then the logic is

if form.is_valid() and form2.is_valid():
    form.save()
    form2.save()
    return HttpResponseRedirect(reverse("MyTaskLists:my_task_list_main_menu"))

context["form"] = form
context["form2"] = form2
return render(request, "my_task_list_tasklist_detail.html", context)

If there is any field with the same name in form and form2 you need to use a prefix to remove the ambiguity.

form = UpdateTaskListForm(request.POST or None, instance=obj, prefix='form1')
form2 = TaskForm(request.POST or None, prefix='form2')
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文