mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Clarified docs for some tags and filters
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							5649c0af9d
						
					
				
				
					commit
					1ccdc08189
				
			| @@ -60,6 +60,8 @@ Sample usage:: | ||||
|         <p>Commented out text with {{ create_date|date:"c" }}</p> | ||||
|     {% endcomment %} | ||||
|  | ||||
| ``comment`` tags cannot be nested. | ||||
|  | ||||
| .. templatetag:: csrf_token | ||||
|  | ||||
| csrf_token | ||||
| @@ -73,10 +75,12 @@ This tag is used for CSRF protection, as described in the documentation for | ||||
| cycle | ||||
| ^^^^^ | ||||
|  | ||||
| Cycles among the given strings or variables each time this tag is encountered. | ||||
| Produces one of its arguments each time this tag is encountered. The first | ||||
| argument is produced on the first encounter, the second argument on the second | ||||
| encounter, and so forth. Once all arguments are exhausted, the tag cycles to | ||||
| the first argument and produces it again. | ||||
|  | ||||
| Within a loop, cycles among the given strings each time through the | ||||
| loop:: | ||||
| This tag is particularly useful in a loop:: | ||||
|  | ||||
|     {% for o in some_list %} | ||||
|         <tr class="{% cycle 'row1' 'row2' %}"> | ||||
| @@ -84,8 +88,13 @@ loop:: | ||||
|         </tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| The first iteration produces HTML that refers to class ``row1``, the second to | ||||
| ``row2``, the third to ``row1`` again, and so on for each iteration of the | ||||
| loop. | ||||
|  | ||||
| You can use variables, too. For example, if you have two template variables, | ||||
| ``rowvalue1`` and ``rowvalue2``, you can cycle between their values like this:: | ||||
| ``rowvalue1`` and ``rowvalue2``, you can alternate between their values like | ||||
| this:: | ||||
|  | ||||
|     {% for o in some_list %} | ||||
|         <tr class="{% cycle rowvalue1 rowvalue2 %}"> | ||||
| @@ -93,9 +102,10 @@ You can use variables, too. For example, if you have two template variables, | ||||
|         </tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| Note that variable arguments (``rowvalue1`` and ``rowvalue2`` above) are NOT | ||||
| auto-escaped! So either make sure that you trust their values, or use explicit | ||||
| escaping, like this:: | ||||
| Note that the variables included in the cycle will not be escaped. Any HTML or | ||||
| Javascript code contained in the printed variable will be rendered as-is, which | ||||
| could potentially lead to security issues. So either make sure that you trust | ||||
| their values or use explicit escaping like this:: | ||||
|  | ||||
|     {% for o in some_list %} | ||||
|         <tr class="{% filter force_escape %}{% cycle rowvalue1 rowvalue2 %}{% endfilter %}"> | ||||
| @@ -111,17 +121,17 @@ You can mix variables and strings:: | ||||
|         </tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| In some cases you might want to refer to the next value of a cycle from | ||||
| outside of a loop. To do this, just give the ``{% cycle %}`` tag a name, using | ||||
| "as", like this:: | ||||
| In some cases you might want to refer to the current value of a cycle | ||||
| without advancing to the next value. To do this, | ||||
| just give the ``{% cycle %}`` tag a name, using "as", like this:: | ||||
|  | ||||
|     {% cycle 'row1' 'row2' as rowcolors %} | ||||
|  | ||||
| From then on, you can insert the current value of the cycle wherever | ||||
| you'd like in your template by referencing the cycle name as a context | ||||
| variable. If you want to move the cycle onto the next value, you use | ||||
| the cycle tag again, using the name of the variable. So, the following | ||||
| template:: | ||||
| From then on, you can insert the current value of the cycle wherever you'd like | ||||
| in your template by referencing the cycle name as a context variable. If you | ||||
| want to move the cycle to the next value independently of the original | ||||
| ``cycle`` tag, you can use another ``cycle`` tag and specify the name of the | ||||
| variable. So, the following template:: | ||||
|  | ||||
|     <tr> | ||||
|         <td class="{% cycle 'row1' 'row2' as rowcolors %}">...</td> | ||||
| @@ -143,15 +153,39 @@ would output:: | ||||
|         <td class="row2">...</td> | ||||
|     </tr> | ||||
|  | ||||
| You can use any number of values in a ``{% cycle %}`` tag, separated by spaces. | ||||
| Values enclosed in single (``'``) or double quotes (``"``) are treated as | ||||
| string literals, while values without quotes are treated as template variables. | ||||
| You can use any number of values in a ``cycle`` tag, separated by spaces. | ||||
| Values enclosed in single quotes (``'``) or double quotes (``"``) are treated | ||||
| as string literals, while values without quotes are treated as template | ||||
| variables. | ||||
|  | ||||
| Note that currently the variables included in the cycle will not be escaped. | ||||
| Any HTML or Javascript code contained in the printed variable will be rendered | ||||
| as-is, which could potentially lead to security issues. | ||||
| By default, when you use the ``as`` keyword with the cycle tag, the | ||||
| usage of ``{% cycle %}`` that initiates the cycle will itself produce | ||||
| the first value in the cycle. This could be a problem if you want to | ||||
| use the value in a nested loop or an included template. If you only want | ||||
| to declare the cycle but not produce the first value, you can add a | ||||
| ``silent`` keyword as the last keyword in the tag. For example:: | ||||
|  | ||||
| For backwards compatibility, the ``{% cycle %}`` tag supports the much inferior | ||||
|     {% for obj in some_list %} | ||||
|         {% cycle 'row1' 'row2' as rowcolors silent %} | ||||
|         <tr class="{{ rowcolors }}">{% include "subtemplate.html" %}</tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| This will output a list of ``<tr>`` elements with ``class`` | ||||
| alternating between ``row1`` and ``row2``. The subtemplate will have | ||||
| access to ``rowcolors`` in its context and the value will match the class | ||||
| of the ``<tr>`` that encloses it. If the ``silent`` keyword were to be | ||||
| omitted, ``row1`` and ``row2`` would be emitted as normal text, outside the | ||||
| ``<tr>`` element. | ||||
|  | ||||
| When the silent keyword is used on a cycle definition, the silence | ||||
| automatically applies to all subsequent uses of that specific cycle tag. | ||||
| The following template would output *nothing*, even though the second | ||||
| call to ``{% cycle %}`` doesn't specify ``silent``:: | ||||
|  | ||||
|     {% cycle 'row1' 'row2' as rowcolors silent %} | ||||
|     {% cycle rowcolors %} | ||||
|  | ||||
| For backward compatibility, the ``{% cycle %}`` tag supports the much inferior | ||||
| old syntax from previous Django versions. You shouldn't use this in any new | ||||
| projects, but for the sake of the people who are still using it, here's what it | ||||
| looks like:: | ||||
| @@ -162,48 +196,21 @@ In this syntax, each value gets interpreted as a literal string, and there's no | ||||
| way to specify variable values. Or literal commas. Or spaces. Did we mention | ||||
| you shouldn't use this syntax in any new projects? | ||||
|  | ||||
| By default, when you use the ``as`` keyword with the cycle tag, the | ||||
| usage of ``{% cycle %}`` that declares the cycle will itself output | ||||
| the first value in the cycle. This could be a problem if you want to | ||||
| use the value in a nested loop or an included template. If you want to | ||||
| just declare the cycle, but not output the first value, you can add a | ||||
| ``silent`` keyword as the last keyword in the tag. For example:: | ||||
|  | ||||
|     {% for obj in some_list %} | ||||
|         {% cycle 'row1' 'row2' as rowcolors silent %} | ||||
|         <tr class="{{ rowcolors }}">{% include "subtemplate.html" %}</tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| This will output a list of ``<tr>`` elements with ``class`` | ||||
| alternating between ``row1`` and ``row2``; the subtemplate will have | ||||
| access to ``rowcolors`` in its context that matches the class of the | ||||
| ``<tr>`` that encloses it. If the ``silent`` keyword were to be | ||||
| omitted, ``row1`` would be emitted as normal text, outside the | ||||
| ``<tr>`` element. | ||||
|  | ||||
| When the silent keyword is used on a cycle definition, the silence | ||||
| automatically applies to all subsequent uses of the cycle tag. In, | ||||
| the following template would output *nothing*, even though the second | ||||
| call to ``{% cycle %}`` doesn't specify silent:: | ||||
|  | ||||
|     {% cycle 'row1' 'row2' as rowcolors silent %} | ||||
|     {% cycle rowcolors %} | ||||
|  | ||||
| .. versionchanged:: 1.6 | ||||
|  | ||||
|     To improve safety, future versions of ``cycle`` will automatically escape | ||||
|     their output. You're encouraged to activate this behavior by loading | ||||
|     ``cycle`` from the ``future`` template library:: | ||||
| To improve safety, future versions of ``cycle`` will automatically escape | ||||
| their output. You're encouraged to activate this behavior by loading | ||||
| ``cycle`` from the ``future`` template library:: | ||||
|  | ||||
|         {% load cycle from future %} | ||||
|     {% load cycle from future %} | ||||
|  | ||||
|     When using the ``future`` version, you can disable auto-escaping with:: | ||||
| When using the ``future`` version, you can disable auto-escaping with:: | ||||
|  | ||||
|         {% for o in some_list %} | ||||
|             <tr class="{% autoescape off %}{% cycle rowvalue1 rowvalue2 %}{% endautoescape %}"> | ||||
|                 ... | ||||
|             </tr> | ||||
|         {% endfor %} | ||||
|     {% for o in some_list %} | ||||
|         <tr class="{% autoescape off %}{% cycle rowvalue1 rowvalue2 %}{% endautoescape %}"> | ||||
|             ... | ||||
|         </tr> | ||||
|     {% endfor %} | ||||
|  | ||||
| .. templatetag:: debug | ||||
|  | ||||
| @@ -237,10 +244,12 @@ See :ref:`template-inheritance` for more information. | ||||
| filter | ||||
| ^^^^^^ | ||||
|  | ||||
| Filters the contents of the variable through variable filters. | ||||
| Filters the contents of the block through one or more filters. Multiple | ||||
| filters can be specified with pipes and filters can have arguments, just as | ||||
| in variable syntax. | ||||
|  | ||||
| Filters can also be piped through each other, and they can have arguments -- | ||||
| just like in variable syntax. | ||||
| Note that the block includes *all* the text between the ``filter`` and | ||||
| ``endfilter`` tags. | ||||
|  | ||||
| Sample usage:: | ||||
|  | ||||
| @@ -259,8 +268,8 @@ Sample usage:: | ||||
| firstof | ||||
| ^^^^^^^ | ||||
|  | ||||
| Outputs the first variable passed that is not False. Does NOT auto-escape | ||||
| variable values. | ||||
| Outputs the first argument variable that is not False. This tag does *not* | ||||
| auto-escape variable values. | ||||
|  | ||||
| Outputs nothing if all the passed variables are False. | ||||
|  | ||||
| @@ -315,8 +324,9 @@ to escape the variables in the firstof tag, you must do so explicitly:: | ||||
| for | ||||
| ^^^ | ||||
|  | ||||
| Loop over each item in an array.  For example, to display a list of athletes | ||||
| provided in ``athlete_list``:: | ||||
| Loops over each item in an array, making the item available in a context | ||||
| variable. For example, to display a list of athletes provided in | ||||
| ``athlete_list``:: | ||||
|  | ||||
|     <ul> | ||||
|     {% for athlete in athlete_list %} | ||||
| @@ -328,7 +338,7 @@ You can loop over a list in reverse by using | ||||
| ``{% for obj in list reversed %}``. | ||||
|  | ||||
| If you need to loop over a list of lists, you can unpack the values | ||||
| in each sub-list into individual variables. For example, if your context | ||||
| in each sublist into individual variables. For example, if your context | ||||
| contains a list of (x,y) coordinates called ``points``, you could use the | ||||
| following to output the list of points:: | ||||
|  | ||||
| @@ -357,14 +367,14 @@ Variable                    Description | ||||
|                             loop (0-indexed) | ||||
| ``forloop.first``           True if this is the first time through the loop | ||||
| ``forloop.last``            True if this is the last time through the loop | ||||
| ``forloop.parentloop``      For nested loops, this is the loop "above" the | ||||
|                             current one | ||||
| ``forloop.parentloop``      For nested loops, this is the loop surrounding | ||||
|                             the current one | ||||
| ==========================  =============================================== | ||||
|  | ||||
| for ... empty | ||||
| ^^^^^^^^^^^^^ | ||||
|  | ||||
| The ``for`` tag can take an optional ``{% empty %}`` clause that will be | ||||
| The ``for`` tag can take an optional ``{% empty %}`` clause whose text is | ||||
| displayed if the given array is empty or could not be found:: | ||||
|  | ||||
|     <ul> | ||||
| @@ -451,7 +461,7 @@ will be interpreted like: | ||||
|  | ||||
|     if (athlete_list and coach_list) or cheerleader_list | ||||
|  | ||||
| Use of actual parentheses in the :ttag:`if` tag is invalid syntax.  If you need | ||||
| Use of actual parentheses in the :ttag:`if` tag is invalid syntax. If you need | ||||
| them to indicate precedence, you should use nested :ttag:`if` tags. | ||||
|  | ||||
| :ttag:`if` tags may also use the operators ``==``, ``!=``, ``<``, ``>``, | ||||
| @@ -517,7 +527,7 @@ Greater than or equal to. Example:: | ||||
| ^^^^^^^^^^^^^^^ | ||||
|  | ||||
| Contained within. This operator is supported by many Python containers to test | ||||
| whether the given value is in the container.  The following are some examples | ||||
| whether the given value is in the container. The following are some examples | ||||
| of how ``x in y`` will be interpreted:: | ||||
|  | ||||
|     {% if "bc" in "abcdef" %} | ||||
| @@ -537,7 +547,7 @@ of how ``x in y`` will be interpreted:: | ||||
| ``not in`` operator | ||||
| ^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| Not contained within.  This is the negation of the ``in`` operator. | ||||
| Not contained within. This is the negation of the ``in`` operator. | ||||
|  | ||||
|  | ||||
| The comparison operators cannot be 'chained' like in Python or in mathematical | ||||
| @@ -564,7 +574,7 @@ Complex expressions | ||||
|  | ||||
| All of the above can be combined to form complex expressions. For such | ||||
| expressions, it can be important to know how the operators are grouped when the | ||||
| expression is evaluated - that is, the precedence rules.  The precedence of the | ||||
| expression is evaluated - that is, the precedence rules. The precedence of the | ||||
| operators, from lowest to highest, is as follows: | ||||
|  | ||||
| * ``or`` | ||||
| @@ -697,8 +707,8 @@ the variable ``template_name``:: | ||||
|     accepts a context. This allows you to reference a compiled ``Template`` in | ||||
|     your context. | ||||
|  | ||||
| An included template is rendered with the context of the template that's | ||||
| including it. This example produces the output ``"Hello, John"``: | ||||
| An included template is rendered within the context of the template that | ||||
| includes it. This example produces the output ``"Hello, John"``: | ||||
|  | ||||
| * Context: variable ``person`` is set to ``"john"``. | ||||
| * Template:: | ||||
| @@ -713,8 +723,9 @@ You can pass additional context to the template using keyword arguments:: | ||||
|  | ||||
|     {% include "name_snippet.html" with person="Jane" greeting="Hello" %} | ||||
|  | ||||
| If you want to only render the context with the variables provided (or even | ||||
| no variables at all), use the ``only`` option:: | ||||
| If you want to render the context only with the variables provided (or even | ||||
| no variables at all), use the ``only`` option. No other variables are | ||||
| available to the included template:: | ||||
|  | ||||
|     {% include "name_snippet.html" with greeting="Hi" only %} | ||||
|  | ||||
| @@ -1194,7 +1205,8 @@ If ``value`` is ``"I'm using Django"``, the output will be | ||||
| capfirst | ||||
| ^^^^^^^^ | ||||
|  | ||||
| Capitalizes the first character of the value. | ||||
| Capitalizes the first character of the value. If the first character is not | ||||
| a letter, this filter has no effect. | ||||
|  | ||||
| For example:: | ||||
|  | ||||
| @@ -1922,9 +1934,9 @@ autoescaping is off, this filter has no effect. | ||||
| safeseq | ||||
| ^^^^^^^ | ||||
|  | ||||
| Applies the :tfilter:`safe` filter to each element of a sequence.  Useful in | ||||
| Applies the :tfilter:`safe` filter to each element of a sequence. Useful in | ||||
| conjunction with other filters that operate on sequences, such as | ||||
| :tfilter:`join`.  For example:: | ||||
| :tfilter:`join`. For example:: | ||||
|  | ||||
|     {{ some_list|safeseq|join:", " }} | ||||
|  | ||||
| @@ -2081,7 +2093,8 @@ date that is in the past relative to the comparison point. | ||||
| title | ||||
| ^^^^^ | ||||
|  | ||||
| Converts a string into titlecase. | ||||
| Converts a string into titlecase by capitalizing each word in the string. | ||||
| This tag makes no effort to keep "trivial words" in lowercase. | ||||
|  | ||||
| For example:: | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user