我想对表单使用django 1.3的基于类的通用视图,但有时必须在一种表单中管理多个表单类。但是,看起来基于FormMixin的现有视图假定了一个表单类。
通用视图是否有可能,我将如何做?
编辑:澄清一下,我有一种形式,但不止一种(基于ModelForm的)类。例如,在django文档的inline_formset示例中,我想展示一个页面,在其中可以以一种形式一次编辑作者和他的书:
author_form = AuthorForm(request.POST, instance = author) books_formset = BookInlineFormSet(request.POST, request.FILES, instance=author)
面对类似的问题,我得出结论认为这是不可能的。
虽然每页本身具有多种形式,但事实证明这是设计错误,但会带来各种麻烦。例如,用户填写了两个表单,在其中一个表单上单击提交,从另一个表单中丢失数据。解决方法需要复杂的控制器,该控制器需要知道页面上所有表单的状态
如果不是每页有多个表单不是你的确切要求,则建议你考虑其他解决方案。
例如,通常可以一次仅向用户显示一个可编辑的表单。
在我的情况下,我切换到了django-formwizard(不是django.contrib,它有点旧,似乎正在重新设计中,但是此 更新:从Django 1.4版本开始,django-formwizardapp将在中可用django.contrib,代替旧的formwizard已在行李箱中,请参阅docs。对于用户,我使它看起来好像页面上实际上有多个表单,但是只有一个是可编辑的。用户必须按预定顺序填写表格。这使得处理多种形式变得更加容易。
django-formwizard
django-formwizardapp
django.contrib
formwizard
否则,如果确实需要一次全部呈现表单,则可以将它们组合成一个表单。
更新(在你澄清之后):
不,你也不能使用通用的表单集FormView。尽管你的示例似乎很容易实现:我认为它与Formset上Django文档中的示例非常相似。它处理两个表单集,你只需要用表单替换一个表单集(我认为你仍然需要指定前缀以避免元素id属性的可能冲突)。
简而言之,在你的情况下,我将使用子类django.views.generic.base.View,override get()和post()方法来处理表单和表单集,类似于Django文档中的上述示例。
django.views.generic.base.View,override get()
在这种情况下,我认为同时显示可编辑的表单和表单集都很好,只需一个按钮即可提交它们。
另一个更新:
Django trac中有一个有效的近期票据,#16256更多基于类的视图:表单集派生了通用视图。如果一切顺利,新的通用视图将被添加到Django的:FormSetsView,ModelFormSetsView和InlineFormSetsView。特别是最后一个“提供了一种使用内联表单集显示和处理模型的方法”。