3

私は自分のフォーム用に非常に特殊な HTML デザインを持っているので、すべて HTML で記述する必要があり、これにはデフォルトのフォーム レンダラーは使用しません。

この SelectDateWidget を Django フォームに設定しました。SelectDateWidget を除いてすべて正常に動作します。フォームが無効な場合は、関連するすべての値を収集し、カスタム HTML フィールドに再入力します。問題は、テンプレートで SelectDateWidget の値を取得できないように見えることです。

form.mydate_day.value、 、などを試しform.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" />
4

1 に答える 1

0

次のような form.data を使用できます。

{% if form.data.date_naissance_day == i %}selected{% endif %}
于 2015-06-28T02:56:11.743 に答える