1
0
mirror of https://github.com/django/django.git synced 2025-10-24 22:26:08 +00:00

[1.1.X] Fixed #10361 -- Added documentation for ComboField and MultiValueField form fields, patch from timo.

Backport of r12798 from trunk.


git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.1.X@12799 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Gary Wilson Jr
2010-03-16 21:03:11 +00:00
parent e15c850f1b
commit 58d72d4fee

View File

@@ -695,7 +695,6 @@ If no ``input_formats`` argument is provided, the default input formats are::
Takes the following optional arguments: Takes the following optional arguments:
.. attribute:: URLField.max_length .. attribute:: URLField.max_length
.. attribute:: URLField.min_length .. attribute:: URLField.min_length
@@ -714,12 +713,65 @@ Takes the following optional arguments:
Slightly complex built-in ``Field`` classes Slightly complex built-in ``Field`` classes
------------------------------------------- -------------------------------------------
The following are not yet documented. ``ComboField``
~~~~~~~~~~~~~~
.. class:: ComboField(**kwargs) .. class:: ComboField(**kwargs)
* Default widget: ``TextInput``
* Empty value: ``''`` (an empty string)
* Normalizes to: A Unicode object.
* Validates that the given value against each of the fields specified
as an argument to the ``ComboField``.
* Error message keys: ``required``, ``invalid``
Takes one extra required argument:
.. attribute:: ComboField.fields
The list of fields that should be used to validate the field's value (in
the order in which they are provided).
>>> f = ComboField(fields=[CharField(max_length=20), EmailField()])
>>> f.clean('test@example.com')
u'test@example.com'
>>> f.clean('longemailaddress@example.com')
Traceback (most recent call last):
...
ValidationError: [u'Ensure this value has at most 20 characters (it has 28).']
``MultiValuefield``
~~~~~~~~~~~~~~~~~~~
.. class:: MultiValueField(**kwargs) .. class:: MultiValueField(**kwargs)
* Default widget: ``TextInput``
* Empty value: ``''`` (an empty string)
* Normalizes to: the type returned by the ``compress`` method of the subclass.
* Validates that the given value against each of the fields specified
as an argument to the ``MultiValueField``.
* Error message keys: ``required``, ``invalid``
This abstract field (must be subclassed) aggregates the logic of multiple
fields. Subclasses should not have to implement clean(). Instead, they must
implement compress(), which takes a list of valid values and returns a
"compressed" version of those values -- a single value. For example,
:class:`SplitDateTimeField` is a subclass which combines a time field and
a date field into a datetime object.
Takes one extra required argument:
.. attribute:: MultiValueField.fields
A list of fields which are cleaned into a single field. Each value in
``clean`` is cleaned by the corresponding field in ``fields`` -- the first
value is cleaned by the first field, the second value is cleaned by
the second field, etc. Once all fields are cleaned, the list of clean
values is "compressed" into a single value.
``SplitDateTimeField``
~~~~~~~~~~~~~~~~~~~~~~
.. class:: SplitDateTimeField(**kwargs) .. class:: SplitDateTimeField(**kwargs)
* Default widget: ``SplitDateTimeWidget`` * Default widget: ``SplitDateTimeWidget``
@@ -782,11 +834,11 @@ representing a foreign key. A single argument is required:
.. attribute:: ModelChoiceField.empty_label .. attribute:: ModelChoiceField.empty_label
By default the ``<select>`` widget used by ``ModelChoiceField`` will have a By default the ``<select>`` widget used by ``ModelChoiceField`` will have a
an empty choice at the top of the list. You can change the text of this label an empty choice at the top of the list. You can change the text of this
(which is ``"---------"`` by default) with the ``empty_label`` attribute, or label (which is ``"---------"`` by default) with the ``empty_label``
you can disable the empty label entirely by setting ``empty_label`` to attribute, or you can disable the empty label entirely by setting
``None``:: ``empty_label`` to ``None``::
# A custom empty label # A custom empty label
field1 = forms.ModelChoiceField(queryset=..., empty_label="(Nothing)") field1 = forms.ModelChoiceField(queryset=..., empty_label="(Nothing)")
@@ -794,9 +846,9 @@ representing a foreign key. A single argument is required:
# No empty label # No empty label
field2 = forms.ModelChoiceField(queryset=..., empty_label=None) field2 = forms.ModelChoiceField(queryset=..., empty_label=None)
Note that if a ``ModelChoiceField`` is required and has a default Note that if a ``ModelChoiceField`` is required and has a default
initial value, no empty choice is created (regardless of the value initial value, no empty choice is created (regardless of the value
of ``empty_label``). of ``empty_label``).
The ``__unicode__`` method of the model will be called to generate The ``__unicode__`` method of the model will be called to generate
string representations of the objects for use in the field's choices; string representations of the objects for use in the field's choices;