mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Refs #32338 -- Improved accessibility of RadioSelect examples in docs.
Co-authored-by: Thibaud Colas <thibaudcolas@gmail.com>
This commit is contained in:
committed by
Mariusz Felisiak
parent
0393b9262d
commit
d8c17aa10c
@@ -20,16 +20,16 @@ tutorial, so that the template contains an HTML ``<form>`` element:
|
|||||||
.. code-block:: html+django
|
.. code-block:: html+django
|
||||||
:caption: polls/templates/polls/detail.html
|
:caption: polls/templates/polls/detail.html
|
||||||
|
|
||||||
<h1>{{ question.question_text }}</h1>
|
|
||||||
|
|
||||||
{% if error_message %}<p><strong>{{ error_message }}</strong></p>{% endif %}
|
|
||||||
|
|
||||||
<form action="{% url 'polls:vote' question.id %}" method="post">
|
<form action="{% url 'polls:vote' question.id %}" method="post">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
{% for choice in question.choice_set.all %}
|
<fieldset>
|
||||||
<input type="radio" name="choice" id="choice{{ forloop.counter }}" value="{{ choice.id }}">
|
<legend><h1>{{ question.question_text }}</h1></legend>
|
||||||
<label for="choice{{ forloop.counter }}">{{ choice.choice_text }}</label><br>
|
{% if error_message %}<p><strong>{{ error_message }}</strong></p>{% endif %}
|
||||||
{% endfor %}
|
{% for choice in question.choice_set.all %}
|
||||||
|
<input type="radio" name="choice" id="choice{{ forloop.counter }}" value="{{ choice.id }}">
|
||||||
|
<label for="choice{{ forloop.counter }}">{{ choice.choice_text }}</label><br>
|
||||||
|
{% endfor %}
|
||||||
|
</fieldset>
|
||||||
<input type="submit" value="Vote">
|
<input type="submit" value="Vote">
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
@@ -718,28 +718,34 @@ that specifies the template used to render each choice. For example, for the
|
|||||||
|
|
||||||
.. code-block:: html+django
|
.. code-block:: html+django
|
||||||
|
|
||||||
{% for radio in myform.beatles %}
|
<fieldset>
|
||||||
<div class="myradio">
|
<legend>{{ myform.beatles.label }}</legend>
|
||||||
{{ radio }}
|
{% for radio in myform.beatles %}
|
||||||
</div>
|
<div class="myradio">
|
||||||
{% endfor %}
|
{{ radio }}
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
This would generate the following HTML:
|
This would generate the following HTML:
|
||||||
|
|
||||||
.. code-block:: html
|
.. code-block:: html
|
||||||
|
|
||||||
<div class="myradio">
|
<fieldset>
|
||||||
<label for="id_beatles_0"><input id="id_beatles_0" name="beatles" type="radio" value="john" required> John</label>
|
<legend>Radio buttons</legend>
|
||||||
</div>
|
<div class="myradio">
|
||||||
<div class="myradio">
|
<label for="id_beatles_0"><input id="id_beatles_0" name="beatles" type="radio" value="john" required> John</label>
|
||||||
<label for="id_beatles_1"><input id="id_beatles_1" name="beatles" type="radio" value="paul" required> Paul</label>
|
</div>
|
||||||
</div>
|
<div class="myradio">
|
||||||
<div class="myradio">
|
<label for="id_beatles_1"><input id="id_beatles_1" name="beatles" type="radio" value="paul" required> Paul</label>
|
||||||
<label for="id_beatles_2"><input id="id_beatles_2" name="beatles" type="radio" value="george" required> George</label>
|
</div>
|
||||||
</div>
|
<div class="myradio">
|
||||||
<div class="myradio">
|
<label for="id_beatles_2"><input id="id_beatles_2" name="beatles" type="radio" value="george" required> George</label>
|
||||||
<label for="id_beatles_3"><input id="id_beatles_3" name="beatles" type="radio" value="ringo" required> Ringo</label>
|
</div>
|
||||||
</div>
|
<div class="myradio">
|
||||||
|
<label for="id_beatles_3"><input id="id_beatles_3" name="beatles" type="radio" value="ringo" required> Ringo</label>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
That included the ``<label>`` tags. To get more granular, you can use each
|
That included the ``<label>`` tags. To get more granular, you can use each
|
||||||
radio button's ``tag``, ``choice_label`` and ``id_for_label`` attributes.
|
radio button's ``tag``, ``choice_label`` and ``id_for_label`` attributes.
|
||||||
@@ -747,36 +753,39 @@ that specifies the template used to render each choice. For example, for the
|
|||||||
|
|
||||||
.. code-block:: html+django
|
.. code-block:: html+django
|
||||||
|
|
||||||
{% for radio in myform.beatles %}
|
<fieldset>
|
||||||
|
<legend>{{ myform.beatles.label }}</legend>
|
||||||
|
{% for radio in myform.beatles %}
|
||||||
<label for="{{ radio.id_for_label }}">
|
<label for="{{ radio.id_for_label }}">
|
||||||
{{ radio.choice_label }}
|
{{ radio.choice_label }}
|
||||||
<span class="radio">{{ radio.tag }}</span>
|
<span class="radio">{{ radio.tag }}</span>
|
||||||
</label>
|
</label>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
...will result in the following HTML:
|
...will result in the following HTML:
|
||||||
|
|
||||||
.. code-block:: html
|
.. code-block:: html
|
||||||
|
|
||||||
<label for="id_beatles_0">
|
<fieldset>
|
||||||
John
|
<legend>Radio buttons</legend>
|
||||||
<span class="radio"><input id="id_beatles_0" name="beatles" type="radio" value="john" required></span>
|
<label for="id_beatles_0">
|
||||||
</label>
|
John
|
||||||
|
<span class="radio"><input id="id_beatles_0" name="beatles" type="radio" value="john" required></span>
|
||||||
<label for="id_beatles_1">
|
</label>
|
||||||
Paul
|
<label for="id_beatles_1">
|
||||||
<span class="radio"><input id="id_beatles_1" name="beatles" type="radio" value="paul" required></span>
|
Paul
|
||||||
</label>
|
<span class="radio"><input id="id_beatles_1" name="beatles" type="radio" value="paul" required></span>
|
||||||
|
</label>
|
||||||
<label for="id_beatles_2">
|
<label for="id_beatles_2">
|
||||||
George
|
George
|
||||||
<span class="radio"><input id="id_beatles_2" name="beatles" type="radio" value="george" required></span>
|
<span class="radio"><input id="id_beatles_2" name="beatles" type="radio" value="george" required></span>
|
||||||
</label>
|
</label>
|
||||||
|
<label for="id_beatles_3">
|
||||||
<label for="id_beatles_3">
|
Ringo
|
||||||
Ringo
|
<span class="radio"><input id="id_beatles_3" name="beatles" type="radio" value="ringo" required></span>
|
||||||
<span class="radio"><input id="id_beatles_3" name="beatles" type="radio" value="ringo" required></span>
|
</label>
|
||||||
</label>
|
</fieldset>
|
||||||
|
|
||||||
If you decide not to loop over the radio buttons -- e.g., if your template
|
If you decide not to loop over the radio buttons -- e.g., if your template
|
||||||
includes ``{{ myform.beatles }}`` -- they'll be output in a ``<ul>`` with
|
includes ``{{ myform.beatles }}`` -- they'll be output in a ``<ul>`` with
|
||||||
|
Reference in New Issue
Block a user