mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +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
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							0393b9262d
						
					
				
				
					commit
					d8c17aa10c
				
			| @@ -20,16 +20,16 @@ tutorial, so that the template contains an HTML ``<form>`` element: | ||||
| .. code-block:: html+django | ||||
|     :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"> | ||||
|     {% csrf_token %} | ||||
|     <fieldset> | ||||
|         <legend><h1>{{ question.question_text }}</h1></legend> | ||||
|         {% if error_message %}<p><strong>{{ error_message }}</strong></p>{% endif %} | ||||
|         {% 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"> | ||||
|     </form> | ||||
|  | ||||
|   | ||||
| @@ -718,16 +718,21 @@ that specifies the template used to render each choice. For example, for the | ||||
|  | ||||
|     .. code-block:: html+django | ||||
|  | ||||
|         <fieldset> | ||||
|             <legend>{{ myform.beatles.label }}</legend> | ||||
|             {% for radio in myform.beatles %} | ||||
|             <div class="myradio"> | ||||
|                 {{ radio }} | ||||
|             </div> | ||||
|             {% endfor %} | ||||
|         </fieldset> | ||||
|  | ||||
|     This would generate the following HTML: | ||||
|  | ||||
|     .. code-block:: html | ||||
|  | ||||
|         <fieldset> | ||||
|             <legend>Radio buttons</legend> | ||||
|             <div class="myradio"> | ||||
|                 <label for="id_beatles_0"><input id="id_beatles_0" name="beatles" type="radio" value="john" required> John</label> | ||||
|             </div> | ||||
| @@ -740,6 +745,7 @@ that specifies the template used to render each choice. For example, for the | ||||
|             <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 | ||||
|     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 | ||||
|  | ||||
|         <fieldset> | ||||
|             <legend>{{ myform.beatles.label }}</legend> | ||||
|             {% for radio in myform.beatles %} | ||||
|             <label for="{{ radio.id_for_label }}"> | ||||
|                 {{ radio.choice_label }} | ||||
|                 <span class="radio">{{ radio.tag }}</span> | ||||
|             </label> | ||||
|             {% endfor %} | ||||
|         </fieldset> | ||||
|  | ||||
|     ...will result in the following HTML: | ||||
|  | ||||
|     .. code-block:: html | ||||
|  | ||||
|         <fieldset> | ||||
|             <legend>Radio buttons</legend> | ||||
|             <label for="id_beatles_0"> | ||||
|                 John | ||||
|                 <span class="radio"><input id="id_beatles_0" name="beatles" type="radio" value="john" required></span> | ||||
|             </label> | ||||
|  | ||||
|             <label for="id_beatles_1"> | ||||
|                 Paul | ||||
|                 <span class="radio"><input id="id_beatles_1" name="beatles" type="radio" value="paul" required></span> | ||||
|             </label> | ||||
|  | ||||
|             <label for="id_beatles_2"> | ||||
|                 George | ||||
|                 <span class="radio"><input id="id_beatles_2" name="beatles" type="radio" value="george" required></span> | ||||
|             </label> | ||||
|  | ||||
|             <label for="id_beatles_3"> | ||||
|                 Ringo | ||||
|                 <span class="radio"><input id="id_beatles_3" name="beatles" type="radio" value="ringo" required></span> | ||||
|             </label> | ||||
|         </fieldset> | ||||
|  | ||||
|     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 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user