私は2つのモデルを持っています、Father
そしてSon
。
登録するページがありますFather
。同じページに、登録するフォームセットがありますSon
。
ページ上には、同じページに別のボタンFather
とそれぞれを追加するための「詳細」ボタンがあります。Son
誰かが使用している例はありますCreateView
か?
私は2つのモデルを持っています、Father
そしてSon
。
登録するページがありますFather
。同じページに、登録するフォームセットがありますSon
。
ページ上には、同じページに別のボタンFather
とそれぞれを追加するための「詳細」ボタンがあります。Son
誰かが使用している例はありますCreateView
か?
クラスベースのビューはまだ新しいので、これについて書きます。プロセスは簡単です。
まず、オブジェクトのフォームを作成します。フォームの 1 つが繰り返されます。ここで行うことは特にありません。
class SonInline(ModelForm):
model = Son
class FatherForm(ModelForm):
model = Father
次に、次を作成しますformset
。
FatherInlineFormSet = inlineformset_factory(Father,
Son,
form=SonInline,
extra=1,
can_delete=False,
can_order=False
)
今、それをあなたと統合するにはCreateView
:
class CreateFatherView(CreateView):
template_name = 'father_create.html'
model = Father
form_class = FatherForm # the parent object's form
# On successful form submission
def get_success_url(self):
return reverse('father-created')
# Validate forms
def form_valid(self, form):
ctx = self.get_context_data()
inlines = ctx['inlines']
if inlines.is_valid() and form.is_valid():
self.object = form.save() # saves Father and Children
return redirect(self.get_success_url())
else:
return self.render_to_response(self.get_context_data(form=form))
def form_invalid(self, form):
return self.render_to_response(self.get_context_data(form=form))
# We populate the context with the forms. Here I'm sending
# the inline forms in `inlines`
def get_context_data(self, **kwargs):
ctx = super(CreateFatherView, self).get_context_data(**kwargs)
if self.request.POST:
ctx['form'] = FatherForm(self.request.POST)
ctx['inlines'] = FatherInlineFormSet(self.request.POST)
else:
ctx['form'] = Father()
ctx['inlines'] = FatherInlineFormSet()
return ctx
最後に、テンプレートは次のとおりです。
重要な部分は、新しいインライン フォームを追加し続けるjquery django-dynamic-formsetプラグインです。
<form id="father-form" method="POST" enctype="multipart/form-data" action=".">
{% csrf_token %}
<div class="row">
{% for f in form %}
<div class="span3">{{ f.label }}<br />{{ f }}
{% if f.errors %}
{% for v in f.errors %}
<br /><span style="color:red;">{{ v }}</span>
{% endfor %}
{% endif %}
</div>
{% endfor %}
</div>
<hr />
<h2>Sons:</h2>
<table class="table-striped">
<table>
{% for f2 in inlines %}
<tr id="{{ f2.prefix }}-row">
{% for i in f2 %}
<td>
{{ i }}{% if i.errors %}<span style="color:red;">{{ i.errors }}</span>{% endif %}
</td>
{% endfor %}
</tr>
{% endfor %}
</table>
{{ inlines.management_form }}
<input type="submit" class="btn btn-primary" value="Go Go Gadget →">
</form>
<script type="text/javascript">
$(function() {
$('#father-form tr').formset({
prefix: '{{ inlines.prefix }}'
});
})
</script>