Django:获取SelectDateWidget的每个子选择的值

3
我有一个非常具体的HTML表单设计,所以我需要将所有内容都编写在HTML中,因此我不使用默认的表单渲染器。
我在Django表单中设置了SelectDateWidget。除了SelectDateWidget外,一切正常:如果我的表单无效,我会收集所有相关值并重新填充我的自定义HTML字段。问题是我似乎不能在模板中获取SelectDateWidget的值。
我尝试了类似于form.mydate_day.valueform.mydate.day_value等等的方法,但是它好像什么也没有包含。
有人可以帮我解决这个问题吗? 谢谢。
如请求所示, 该模型:
class Subscriber(models.Model):
  civilite = models.CharField(max_length=5, verbose_name='Civilite',choices=(('Mlle','Mademoiselle'),('M.','Monsieur'),('Mme','Madame')))
  email = models.EmailField(max_length=255, verbose_name='Email', unique=True)
  nom = models.CharField(max_length=60, verbose_name='Nom')
  prenom = models.CharField(max_length=60, verbose_name='Prenom')
  ville = models.CharField(max_length=50,verbose_name='Ville')
  cp = models.CharField(max_length=5,verbose_name='Code Postal',validators=[RegexValidator(regex='^\d{5}$')])
  date_naissance = models.DateField(auto_now_add=False)
  optin = models.BooleanField(default=True,verbose_name='Optin')
  date_inscription = models.DateField(auto_now_add=True)

表单:
class SubscriberForm(ModelForm):
  class Meta:
    model = Subscriber
    widgets = {
      'civilite': forms.RadioSelect(),
      'date_naissance': extras.SelectDateWidget(years=range(1994,1900,-1)),
    }

视图:
def index(request):
  if request.method == 'POST':
    form = SubscriberForm(request.POST)
    if form.is_valid():
        form.save()
        return HttpResponseRedirect('/coreg.html')
    else:
    form = SubscriberForm()
  return render(request,'index.html', {'form':form,'days':range(1,31),'months':range(1,12),'years':range(1994,1900,-1)})

模板:

模板:

    <label class="lbl" for="jour">Date de naissance :</label>
    <div class="select {% if form.date_naissance.errors  %}error{% endif %}"><span>
      <select name="date_naissance_day" id="jour">
        <option value="--">J</option>
        {% for i in days %}
          <option value="{{i}}" {% if form.date_naissance_day.value == i %}selected{% endif %}>{{i}}</option>
        {% endfor %}
      </select>
    </span></div>
    <div class="select"><span>
      <select name="date_naissance_month" id="mois">
        <option value="--">M</option>
         {% for i in months %}
          <option value="{{i}}" {% if form.date_naissance_month.value == i %}selected{% endif %}>{{i}}</option>
        {% endfor %}
      </select>
    </span></div>
    <div class="select last"><span>
      <select name="date_naissance_year" id="annee">
        <option value="--">A</option>
         {% for i in years %}
          <option value="{{i}}" {% if form.date_naissance_year.value == i %}selected{% endif %}>{{i}}</option>
        {% endfor %}
      </select>
    </span></div>
    <br clear="all" />

好的,不知道为什么我不能在帖子开头说“你好”,它被删除了。所以:你好 :) - user1159791
你是如何实现表单并在模板中显示它的? - Timmy O'Mahony
你已经编辑了这篇帖子。 - user1159791
什么都没有?也许我可以彻底自定义小部件,使其看起来符合我的要求并直接使用它? - user1159791
你最终解决了如何让它工作吗?如果是这样,也许你可以回答自己的问题并帮助其他人,谢谢 ;) - Cloud Artisans
是的,这也让我很烦恼! - Ian Clark
1个回答

0
您可以使用form.data,例如:
{% if form.data.date_naissance_day == i %}selected{% endif %}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接