1
0
mirror of https://github.com/django/django.git synced 2025-10-25 14:46: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:
David Smith
2021-05-14 08:46:22 +01:00
committed by Mariusz Felisiak
parent 0393b9262d
commit d8c17aa10c
2 changed files with 55 additions and 46 deletions

View File

@@ -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>

View File

@@ -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