mirror of
https://github.com/django/django.git
synced 2025-01-26 10:09:42 +00:00
136 lines
4.7 KiB
Plaintext
136 lines
4.7 KiB
Plaintext
|
PostgreSQL specific form fields and widgets
|
||
|
===========================================
|
||
|
|
||
|
All of these fields and widgets are available from the
|
||
|
``django.contrib.postgres.forms`` module.
|
||
|
|
||
|
.. currentmodule:: django.contrib.postgres.forms
|
||
|
|
||
|
SimpleArrayField
|
||
|
----------------
|
||
|
|
||
|
.. class:: SimpleArrayField(base_field, delimiter=',', max_length=None, min_length=None)
|
||
|
|
||
|
A simple field which maps to an array. It is represented by an HTML
|
||
|
``<input>``.
|
||
|
|
||
|
.. attribute:: base_field
|
||
|
|
||
|
This is a required argument.
|
||
|
|
||
|
It specifies the underlying form field for the array. This is not used
|
||
|
to render any HTML, but it is used to process the submitted data and
|
||
|
validate it. For example::
|
||
|
|
||
|
>>> from django.contrib.postgres.forms import SimpleArrayField
|
||
|
>>> from django import forms
|
||
|
|
||
|
>>> class NumberListForm(forms.Form):
|
||
|
... numbers = SimpleArrayField(forms.IntegerField())
|
||
|
|
||
|
>>> form = NumberListForm({'numbers': '1,2,3'})
|
||
|
>>> form.is_valid()
|
||
|
True
|
||
|
>>> form.cleaned_data
|
||
|
{'numbers': [1, 2, 3]}
|
||
|
|
||
|
>>> form = NumberListForm({'numbers': '1,2,a'})
|
||
|
>>> form.is_valid()
|
||
|
False
|
||
|
|
||
|
.. attribute:: delimiter
|
||
|
|
||
|
This is an optional argument which defaults to a comma: ``,``. This
|
||
|
value is used to split the submitted data. It allows you to chain
|
||
|
``SimpleArrayField`` for multidimensional data::
|
||
|
|
||
|
>>> from django.contrib.postgres.forms import SimpleArrayField
|
||
|
>>> from django import forms
|
||
|
|
||
|
>>> class GridForm(forms.Form):
|
||
|
... places = SimpleArrayField(SimpleArrayField(IntegerField()), delimiter='|')
|
||
|
|
||
|
>>> form = GridForm({'places': '1,2|2,1|4,3'})
|
||
|
>>> form.is_valid()
|
||
|
True
|
||
|
>>> form.cleaned_data
|
||
|
{'places': [[1, 2], [2, 1], [4, 3]]}
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
The field does not support escaping of the delimiter, so be careful
|
||
|
in cases where the delimiter is a valid character in the underlying
|
||
|
field. The delimiter does not need to be only one character.
|
||
|
|
||
|
.. attribute:: max_length
|
||
|
|
||
|
This is an optional argument which validates that the array does not
|
||
|
exceed the stated length.
|
||
|
|
||
|
.. attribute:: min_length
|
||
|
|
||
|
This is an optional argument which validates that the array reaches at
|
||
|
least the stated length.
|
||
|
|
||
|
.. admonition:: User friendly forms
|
||
|
|
||
|
``SimpleArrayField`` is not particularly user friendly in most cases,
|
||
|
however it is a useful way to format data from a client-side widget for
|
||
|
submission to the server.
|
||
|
|
||
|
SplitArrayField
|
||
|
---------------
|
||
|
|
||
|
.. class:: SplitArrayField(base_field, size, remove_trailing_nulls=False)
|
||
|
|
||
|
This field handles arrays by reproducing the underlying field a fixed
|
||
|
number of times.
|
||
|
|
||
|
.. attribute:: base_field
|
||
|
|
||
|
This is a required argument. It specifies the form field to be
|
||
|
repeated.
|
||
|
|
||
|
.. attribute:: size
|
||
|
|
||
|
This is the fixed number of times the underlying field will be used.
|
||
|
|
||
|
.. attribute:: remove_trailing_nulls
|
||
|
|
||
|
By default, this is set to ``False``. When ``False``, each value from
|
||
|
the repeated fields is stored. When set to ``True``, any trailing
|
||
|
values which are blank will be stripped from the result. If the
|
||
|
underlying field has ``required=True``, but ``remove_trailing_nulls``
|
||
|
is ``True``, then null values are only allowed at the end, and will be
|
||
|
stripped.
|
||
|
|
||
|
Some examples::
|
||
|
|
||
|
SplitArrayField(IntegerField(required=True), size=3, remove_trailing_nulls=False)
|
||
|
|
||
|
['1', '2', '3'] # -> [1, 2, 3]
|
||
|
['1', '2', ''] # -> ValidationError - third entry required.
|
||
|
['1', '', '3'] # -> ValidationError - second entry required.
|
||
|
['', '2', ''] # -> ValidationError - first and third entries required.
|
||
|
|
||
|
SplitArrayField(IntegerField(required=False), size=3, remove_trailing_nulls=False)
|
||
|
|
||
|
['1', '2', '3'] # -> [1, 2, 3]
|
||
|
['1', '2', ''] # -> [1, 2, None]
|
||
|
['1', '', '3'] # -> [1, None, 3]
|
||
|
['', '2', ''] # -> [None, 2, None]
|
||
|
|
||
|
SplitArrayField(IntegerField(required=True), size=3, remove_trailing_nulls=True)
|
||
|
|
||
|
['1', '2', '3'] # -> [1, 2, 3]
|
||
|
['1', '2', ''] # -> [1, 2]
|
||
|
['1', '', '3'] # -> ValidationError - second entry required.
|
||
|
['', '2', ''] # -> ValidationError - first entry required.
|
||
|
|
||
|
SplitArrayField(IntegerField(required=False), size=3, remove_trailing_nulls=True)
|
||
|
|
||
|
['1', '2', '3'] # -> [1, 2, 3]
|
||
|
['1', '2', ''] # -> [1, 2]
|
||
|
['1', '', '3'] # -> [1, None, 3]
|
||
|
['', '2', ''] # -> [None, 2]
|