【问题标题】: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 数量的子表单(取决于用户有多少孩子)都捆绑在同一个

标记下。

我在创建视图时使用了这个引用:https://collingrady.wordpress.com/2008/02/18/editing-multiple-objects-in-django-with-newforms/

视图看起来应该可以工作。我的问题是模板。诀窍是我不确定每个新用户会有多少个孩子,所以我无法对孩子表单进行硬编码。有谁知道这个问题需要什么样的模板或如何实现我的目标?

【问题讨论】:

  • 您正在寻找表单集,尤其是inline formsets。先让它为固定数量的子表单工作,然后你可以使用 Javascript 动态添加子表单。

标签: 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 应该在一行中,或者应该用

截断

'+ 下一行应该从上面的倒置开始 +'

【讨论】:

    猜你喜欢
    • 2020-02-22
    • 2016-01-22
    • 1970-01-01
    • 2010-09-26
    • 1970-01-01
    • 1970-01-01
    • 2011-07-01
    • 2014-07-16
    • 1970-01-01
    相关资源
    最近更新 更多