私はこのフォームを持っています:
class UserUsesSourceForm(forms.Form):
# some fields here
username = forms.CharField(label=("Username"), max_length=30, help_text = ("Required"))
provider = forms.ChoiceField(widget=forms.Select(), choices=SOURCES_CHOICES, initial=SOURCES_CHOICES[1])
利用可能な選択肢は次のとおりです。
E = 'e'
A = 'a'
SOURCES_CHOICES = (
(A, 'A'),
(E, 'E'),
)
景色:
form = UserUsesSourceForm(initial={"username":request.user.username, 'provider':SOURCES_CHOICES[1]})return render_to_response('update_datasource.html', context_instance=RequestContext(request, params))
そしてテンプレート:
<form action="" method="post">
{% csrf_token %}
{% if form.non_field_errors %}
<p>
{% for error in form.non_field_errors %}
<div class="text-error">{{ error|escape }}</div>
{% endfor %}
</p>
{% endif %}
<div class="control-group">
<label class="control-label" for="id_provider">Data source</label>
<div class="controls">
{{form.provider}}
</div>
</div>
</form>
問題は、初期値が正しく設定されていて、デバッグでテストできる場合でも (つまり、フォームの「プロバイダー」フィールドの初期値が必要なタプルである場合)、最終的な html は常に選択ボックスの最初の要素を表示することです。 :
<select name="provider" id="id_provider">
<option value="A">A</option>
<option value="E">E</option>
</select>
..「デフォルト」または「アクティブ」オプションがあると思いますが。ユーザー名フィールドが正しく初期化されていることに注意してください。問題がどこにあるかを見つけるために、さらに調査するにはどうすればよいですか?