【问题标题】:Django Create Multiple Objects (Same Model) From One FormDjango 从一个表单创建多个对象(相同模型)
【发布时间】:2017-05-07 12:12:51
【问题描述】:
我已经研究这个问题几天了,但没有运气。希望有人可以提供帮助。
假设我们有以下模型:
User model (django.contrib.auth.models)
class Children(models.Model):
name = models.CharField(max_length=200, blank=False)
user = models.ForeignKey(User, on_delete=models.CASCADE)
目标:当新用户想要创建帐户时,他们将填写用户表单并能够将 x 数量的孩子添加到他们的帐户中。本质上,模板将有一个用户表单,以及 x 数量的子表单(取决于用户有多少孩子)都捆绑在同一个
【问题讨论】:
标签:
django
django-models
django-forms
django-templates
django-views
【解决方案1】:
我知道现在回答这个问题有点晚了,但我发现这个没有答案,我想我可以贡献一下
对此可以有多种解决方案。
我可以提一个我相信会满足你需要的。
<!--This is the form for parents and Javascript inserts Dynamic Fields -->
<form id="parent_form" method="POST" action="{% url 'url_name' %}">
<input type="text" name="parent_name">
<input id="child_count" onchange="inject_child_details()"
type="number" name="number_of_children" min=0>
<div id="child_details">
enter code here
</div>
</form>
<script type="text/javascript" nonce="{{script_nonce}}">
function inject_child_details() {
var x = document.getElementById("child_count").value;
details_div = document.getElementById("child_details");
details_div.innerHTML = ''
for(var index = 1;index <= x;){
details_div.insertAdjacentHTML('beforeend','<input type="text" name="child'+index+'name" placeholder="Name of Child '+index+'">');
index = index +1;
}
}
</script>
要插入的 HTML 应该在一行中,或者应该用
截断
'+
下一行应该从上面的倒置开始
+'