13

私はこのフォームを持っています:

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>

..「デフォルト」または「アクティブ」オプションがあると思いますが。ユーザー名フィールドが正しく初期化されていることに注意してください。問題がどこにあるかを見つけるために、さらに調査するにはどうすればよいですか?

4

1 に答える 1