mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #12856 -- Documented BoundField API.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							534aaf56f4
						
					
				
				
					commit
					2f53d342f1
				
			| @@ -767,6 +767,8 @@ method you're using:: | |||||||
|     <p>Sender: <input type="email" name="sender" value="invalid email address" /></p> |     <p>Sender: <input type="email" name="sender" value="invalid email address" /></p> | ||||||
|     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> |     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> | ||||||
|  |  | ||||||
|  | .. _ref-forms-error-list-format: | ||||||
|  |  | ||||||
| Customizing the error list format | Customizing the error list format | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| @@ -792,10 +794,10 @@ Python 2):: | |||||||
|     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> |     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> | ||||||
|  |  | ||||||
| More granular output | More granular output | ||||||
| ~~~~~~~~~~~~~~~~~~~~ | -------------------- | ||||||
|  |  | ||||||
| The ``as_p()``, ``as_ul()`` and ``as_table()`` methods are simply shortcuts for | The ``as_p()``, ``as_ul()``, and ``as_table()`` methods are simply shortcuts -- | ||||||
| lazy developers -- they're not the only way a form object can be displayed. | they're not the only way a form object can be displayed. | ||||||
|  |  | ||||||
| .. class:: BoundField | .. class:: BoundField | ||||||
|  |  | ||||||
| @@ -830,107 +832,180 @@ The field-specific output honors the form object's ``auto_id`` setting:: | |||||||
|     >>> print(f['message']) |     >>> print(f['message']) | ||||||
|     <input type="text" name="message" id="id_message" /> |     <input type="text" name="message" id="id_message" /> | ||||||
|  |  | ||||||
| For a field's list of errors, access the field's ``errors`` attribute. | Attributes of ``BoundField`` | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | .. attribute:: BoundField.data | ||||||
|  |  | ||||||
|  |     This property returns the data for this :class:`~django.forms.BoundField` | ||||||
|  |     extracted by the widget's :meth:`~django.forms.Widget.value_from_datadict` | ||||||
|  |     method, or ``None`` if it wasn't given:: | ||||||
|  |  | ||||||
|  |         >>> unbound_form = ContactForm() | ||||||
|  |         >>> print(unbound_form['subject'].data) | ||||||
|  |         None | ||||||
|  |         >>> bound_form = ContactForm(data={'subject': 'My Subject'}) | ||||||
|  |         >>> print(bound_form['subject'].data) | ||||||
|  |         My Subject | ||||||
|  |  | ||||||
| .. attribute:: BoundField.errors | .. attribute:: BoundField.errors | ||||||
|  |  | ||||||
| A list-like object that is displayed as an HTML ``<ul class="errorlist">`` |     A :ref:`list-like object <ref-forms-error-list-format>` that is displayed | ||||||
| when printed:: |     as an HTML ``<ul class="errorlist">`` when printed:: | ||||||
|  |  | ||||||
|     >>> data = {'subject': 'hi', 'message': '', 'sender': '', 'cc_myself': ''} |         >>> data = {'subject': 'hi', 'message': '', 'sender': '', 'cc_myself': ''} | ||||||
|     >>> f = ContactForm(data, auto_id=False) |         >>> f = ContactForm(data, auto_id=False) | ||||||
|     >>> print(f['message']) |         >>> print(f['message']) | ||||||
|     <input type="text" name="message" /> |         <input type="text" name="message" /> | ||||||
|     >>> f['message'].errors |         >>> f['message'].errors | ||||||
|     ['This field is required.'] |         ['This field is required.'] | ||||||
|     >>> print(f['message'].errors) |         >>> print(f['message'].errors) | ||||||
|     <ul class="errorlist"><li>This field is required.</li></ul> |         <ul class="errorlist"><li>This field is required.</li></ul> | ||||||
|     >>> f['subject'].errors |         >>> f['subject'].errors | ||||||
|     [] |         [] | ||||||
|     >>> print(f['subject'].errors) |         >>> print(f['subject'].errors) | ||||||
|  |  | ||||||
|     >>> str(f['subject'].errors) |         >>> str(f['subject'].errors) | ||||||
|     '' |         '' | ||||||
|  |  | ||||||
| .. method:: BoundField.label_tag(contents=None, attrs=None, label_suffix=None) | .. attribute:: BoundField.field | ||||||
|  |  | ||||||
| To separately render the label tag of a form field, you can call its |     The form :class:`~django.forms.Field` instance from the form class that | ||||||
| ``label_tag`` method:: |     this :class:`~django.forms.BoundField` wraps. | ||||||
|  |  | ||||||
|     >>> f = ContactForm(data) | .. attribute:: BoundField.form | ||||||
|     >>> print(f['message'].label_tag()) |  | ||||||
|     <label for="id_message">Message:</label> |  | ||||||
|  |  | ||||||
| Optionally, you can provide the ``contents`` parameter which will replace the |     The :class:`~django.forms.Form` instance this :class:`~django.forms.BoundField` | ||||||
| auto-generated label tag. An optional ``attrs`` dictionary may contain |     is bound to. | ||||||
| additional attributes for the ``<label>`` tag. |  | ||||||
|  |  | ||||||
| The HTML that's generated includes the form's | .. attribute:: BoundField.help_text | ||||||
| :attr:`~django.forms.Form.label_suffix` (a colon, by default) or, if set, the |  | ||||||
| current field's :attr:`~django.forms.Field.label_suffix`. The optional |  | ||||||
| ``label_suffix`` parameter allows you to override any previously set |  | ||||||
| suffix. For example, you can use an empty string to hide the label on selected |  | ||||||
| fields. If you need to do this in a template, you could write a custom |  | ||||||
| filter to allow passing parameters to ``label_tag``. |  | ||||||
|  |  | ||||||
| .. versionchanged:: 1.8 |     The :attr:`~django.forms.Field.help_text` of the field. | ||||||
|  |  | ||||||
|     The label includes :attr:`~Form.required_css_class` if applicable. | .. attribute:: BoundField.html_name | ||||||
|  |  | ||||||
| .. method:: BoundField.css_classes() |     The name that will be used in the widget's HTML ``name`` attribute. It takes | ||||||
|  |     the form :attr:`~django.forms.Form.prefix` into account. | ||||||
| When you use Django's rendering shortcuts, CSS classes are used to |  | ||||||
| indicate required form fields or fields that contain errors. If you're |  | ||||||
| manually rendering a form, you can access these CSS classes using the |  | ||||||
| ``css_classes`` method:: |  | ||||||
|  |  | ||||||
|     >>> f = ContactForm(data) |  | ||||||
|     >>> f['message'].css_classes() |  | ||||||
|     'required' |  | ||||||
|  |  | ||||||
| If you want to provide some additional classes in addition to the |  | ||||||
| error and required classes that may be required, you can provide |  | ||||||
| those classes as an argument:: |  | ||||||
|  |  | ||||||
|     >>> f = ContactForm(data) |  | ||||||
|     >>> f['message'].css_classes('foo bar') |  | ||||||
|     'foo bar required' |  | ||||||
|  |  | ||||||
| .. method:: BoundField.value() |  | ||||||
|  |  | ||||||
| Use this method to render the raw value of this field as it would be rendered |  | ||||||
| by a ``Widget``:: |  | ||||||
|  |  | ||||||
|     >>> initial = {'subject': 'welcome'} |  | ||||||
|     >>> unbound_form = ContactForm(initial=initial) |  | ||||||
|     >>> bound_form = ContactForm(data, initial=initial) |  | ||||||
|     >>> print(unbound_form['subject'].value()) |  | ||||||
|     welcome |  | ||||||
|     >>> print(bound_form['subject'].value()) |  | ||||||
|     hi |  | ||||||
|  |  | ||||||
| .. attribute:: BoundField.id_for_label | .. attribute:: BoundField.id_for_label | ||||||
|  |  | ||||||
| Use this property to render the ID of this field. For example, if you are |     Use this property to render the ID of this field. For example, if you are | ||||||
| manually constructing a ``<label>`` in your template (despite the fact that |     manually constructing a ``<label>`` in your template (despite the fact that | ||||||
| :meth:`~BoundField.label_tag` will do this for you): |     :meth:`~BoundField.label_tag` will do this for you): | ||||||
|  |  | ||||||
| .. code-block:: html+django |     .. code-block:: html+django | ||||||
|  |  | ||||||
|     <label for="{{ form.my_field.id_for_label }}">...</label>{{ my_field }} |         <label for="{{ form.my_field.id_for_label }}">...</label>{{ my_field }} | ||||||
|  |  | ||||||
| By default, this will be the field's name prefixed by ``id_`` |     By default, this will be the field's name prefixed by ``id_`` | ||||||
| ("``id_my_field``" for the example above). You may modify the ID by setting |     ("``id_my_field``" for the example above). You may modify the ID by setting | ||||||
| :attr:`~django.forms.Widget.attrs` on the field's widget. For example, |     :attr:`~django.forms.Widget.attrs` on the field's widget. For example, | ||||||
| declaring a field like this:: |     declaring a field like this:: | ||||||
|  |  | ||||||
|     my_field = forms.CharField(widget=forms.TextInput(attrs={'id': 'myFIELD'})) |         my_field = forms.CharField(widget=forms.TextInput(attrs={'id': 'myFIELD'})) | ||||||
|  |  | ||||||
| and using the template above, would render something like: |     and using the template above, would render something like: | ||||||
|  |  | ||||||
| .. code-block:: html |     .. code-block:: html | ||||||
|  |  | ||||||
|     <label for="myFIELD">...</label><input id="myFIELD" type="text" name="my_field" /> |         <label for="myFIELD">...</label><input id="myFIELD" type="text" name="my_field" /> | ||||||
|  |  | ||||||
|  | .. attribute:: BoundField.is_hidden | ||||||
|  |  | ||||||
|  |     Returns ``True`` if this :class:`~django.forms.BoundField`'s widget is | ||||||
|  |     hidden. | ||||||
|  |  | ||||||
|  | .. attribute:: BoundField.label | ||||||
|  |  | ||||||
|  |     The :attr:`~django.forms.Field.label` of the field. This is used in | ||||||
|  |     :meth:`~BoundField.label_tag`. | ||||||
|  |  | ||||||
|  | .. attribute:: BoundField.name | ||||||
|  |  | ||||||
|  |     The name of this field in the form:: | ||||||
|  |  | ||||||
|  |         >>> f = ContactForm() | ||||||
|  |         >>> print(f['subject'].name) | ||||||
|  |         subject | ||||||
|  |         >>> print(f['message'].name) | ||||||
|  |         message | ||||||
|  |  | ||||||
|  | Methods of ``BoundField`` | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | .. method:: BoundField.as_hidden(attrs=None, **kwargs) | ||||||
|  |  | ||||||
|  |     Returns a string of HTML for representing this as an ``<input type="hidden">``. | ||||||
|  |  | ||||||
|  |     ``**kwargs`` are passed to :meth:`~django.forms.BoundField.as_widget`. | ||||||
|  |  | ||||||
|  |     This method is primarily used internally. You should use a widget instead. | ||||||
|  |  | ||||||
|  | .. method:: BoundField.as_widget(widget=None, attrs=None, only_initial=False) | ||||||
|  |  | ||||||
|  |     Renders the field by rendering the passed widget, adding any HTML | ||||||
|  |     attributes passed as ``attrs``.  If no widget is specified, then the | ||||||
|  |     field's default widget will be used. | ||||||
|  |  | ||||||
|  |     ``only_initial`` is used by Django internals and should not be set | ||||||
|  |     explicitly. | ||||||
|  |  | ||||||
|  | .. method:: BoundField.css_classes() | ||||||
|  |  | ||||||
|  |     When you use Django's rendering shortcuts, CSS classes are used to | ||||||
|  |     indicate required form fields or fields that contain errors. If you're | ||||||
|  |     manually rendering a form, you can access these CSS classes using the | ||||||
|  |     ``css_classes`` method:: | ||||||
|  |  | ||||||
|  |         >>> f = ContactForm(data={'message': ''}) | ||||||
|  |         >>> f['message'].css_classes() | ||||||
|  |         'required' | ||||||
|  |  | ||||||
|  |     If you want to provide some additional classes in addition to the | ||||||
|  |     error and required classes that may be required, you can provide | ||||||
|  |     those classes as an argument:: | ||||||
|  |  | ||||||
|  |         >>> f = ContactForm(data={'message': ''}) | ||||||
|  |         >>> f['message'].css_classes('foo bar') | ||||||
|  |         'foo bar required' | ||||||
|  |  | ||||||
|  | .. method:: BoundField.label_tag(contents=None, attrs=None, label_suffix=None) | ||||||
|  |  | ||||||
|  |     To separately render the label tag of a form field, you can call its | ||||||
|  |     ``label_tag()`` method:: | ||||||
|  |  | ||||||
|  |         >>> f = ContactForm(data={'message': ''}) | ||||||
|  |         >>> print(f['message'].label_tag()) | ||||||
|  |         <label for="id_message">Message:</label> | ||||||
|  |  | ||||||
|  |     You can provide the ``contents`` parameter which will replace the | ||||||
|  |     auto-generated label tag. An ``attrs`` dictionary may contain additional | ||||||
|  |     attributes for the ``<label>`` tag. | ||||||
|  |  | ||||||
|  |     The HTML that's generated includes the form's | ||||||
|  |     :attr:`~django.forms.Form.label_suffix` (a colon, by default) or, if set, the | ||||||
|  |     current field's :attr:`~django.forms.Field.label_suffix`. The optional | ||||||
|  |     ``label_suffix`` parameter allows you to override any previously set | ||||||
|  |     suffix. For example, you can use an empty string to hide the label on selected | ||||||
|  |     fields. If you need to do this in a template, you could write a custom | ||||||
|  |     filter to allow passing parameters to ``label_tag``. | ||||||
|  |  | ||||||
|  |     .. versionchanged:: 1.8 | ||||||
|  |  | ||||||
|  |         The label includes :attr:`~Form.required_css_class` if applicable. | ||||||
|  |  | ||||||
|  | .. method:: BoundField.value() | ||||||
|  |  | ||||||
|  |     Use this method to render the raw value of this field as it would be rendered | ||||||
|  |     by a ``Widget``:: | ||||||
|  |  | ||||||
|  |         >>> initial = {'subject': 'welcome'} | ||||||
|  |         >>> unbound_form = ContactForm(initial=initial) | ||||||
|  |         >>> bound_form = ContactForm(data={'subject': 'hi'}, initial=initial) | ||||||
|  |         >>> print(unbound_form['subject'].value()) | ||||||
|  |         welcome | ||||||
|  |         >>> print(bound_form['subject'].value()) | ||||||
|  |         hi | ||||||
|  |  | ||||||
| Customizing ``BoundField`` | Customizing ``BoundField`` | ||||||
| -------------------------- | -------------------------- | ||||||
|   | |||||||
| @@ -230,6 +230,16 @@ foundation for custom widgets. | |||||||
|            In older versions, this attribute was only defined on the date |            In older versions, this attribute was only defined on the date | ||||||
|            and time widgets (as ``False``). |            and time widgets (as ``False``). | ||||||
|  |  | ||||||
|  |     .. method:: id_for_label(self, id_) | ||||||
|  |  | ||||||
|  |         Returns the HTML ID attribute of this widget for use by a ``<label>``, | ||||||
|  |         given the ID of the field. Returns ``None`` if an ID isn't available. | ||||||
|  |  | ||||||
|  |         This hook is necessary because some widgets have multiple HTML | ||||||
|  |         elements and, thus, multiple IDs. In that case, this method should | ||||||
|  |         return an ID value that corresponds to the first ID in the widget's | ||||||
|  |         tags. | ||||||
|  |  | ||||||
|     .. method:: render(name, value, attrs=None) |     .. method:: render(name, value, attrs=None) | ||||||
|  |  | ||||||
|         Returns HTML for the widget, as a Unicode string. This method must be |         Returns HTML for the widget, as a Unicode string. This method must be | ||||||
|   | |||||||
| @@ -690,6 +690,11 @@ Useful attributes on ``{{ field }}`` include: | |||||||
|     :class:`~django.forms.Field` attributes, e.g. |     :class:`~django.forms.Field` attributes, e.g. | ||||||
|     ``{{ char_field.field.max_length }}``. |     ``{{ char_field.field.max_length }}``. | ||||||
|  |  | ||||||
|  | .. seealso:: | ||||||
|  |  | ||||||
|  |     For a complete list of attributes and methods, see | ||||||
|  |     :class:`~django.forms.BoundField`. | ||||||
|  |  | ||||||
| Looping over hidden and visible fields | Looping over hidden and visible fields | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user