summaryrefslogtreecommitdiff
path: root/docs/ref/forms
diff options
context:
space:
mode:
authorVajrasky Kok <sky.kok@speaklikeaking.com>2013-12-07 15:13:20 +0800
committerTim Graham <timograham@gmail.com>2014-01-02 19:43:26 -0500
commitea83102d0f0c215ae2bd16a2c8c474ce615bad9a (patch)
treed9dee72eddbe3894fafccef4c6f717411781cd5d /docs/ref/forms
parent7d0a5190328f277b97b1f55171e1fecb22a1e461 (diff)
Fixed #21319 -- Added documentation for the Form.fields attribute.
Thanks pydanny for the report. Also, added documentation about base_fields attribute and its difference with fields attribute.
Diffstat (limited to 'docs/ref/forms')
-rw-r--r--docs/ref/forms/api.txt34
1 files changed, 34 insertions, 0 deletions
diff --git a/docs/ref/forms/api.txt b/docs/ref/forms/api.txt
index ef4da9479e..c8f302b924 100644
--- a/docs/ref/forms/api.txt
+++ b/docs/ref/forms/api.txt
@@ -205,6 +205,40 @@ precedence::
<tr><th>Url:</th><td><input type="url" name="url" /></td></tr>
<tr><th>Comment:</th><td><input type="text" name="comment" /></td></tr>
+Accessing the fields from the form
+----------------------------------
+
+.. attribute:: Form.fields
+
+You can access the fields of :class:`Form` instance from its ``fields``
+attribute::
+
+ >>> for row in f.fields.values(): print(row)
+ ...
+ <django.forms.fields.CharField object at 0x7ffaac632510>
+ <django.forms.fields.URLField object at 0x7ffaac632f90>
+ <django.forms.fields.CharField object at 0x7ffaac3aa050>
+ >>> f.fields['name']
+ <django.forms.fields.CharField object at 0x7ffaac6324d0>
+
+You can alter the field of :class:`Form` instance to change the way it is
+presented in the form::
+
+ >>> f.as_table().split('\n')[0]
+ '<tr><th>Name:</th><td><input name="name" type="text" value="instance" /></td></tr>'
+ >>> f.fields['name'].label = "Username"
+ >>> f.as_table().split('\n')[0]
+ '<tr><th>Username:</th><td><input name="name" type="text" value="instance" /></td></tr>'
+
+Beware not to alter the ``base_fields`` attribute because this modification
+will influence all subsequent ``ContactForm`` instances within the same Python
+process::
+
+ >>> f.base_fields['name'].label = "Username"
+ >>> another_f = CommentForm(auto_id=False)
+ >>> another_f.as_table().split('\n')[0]
+ '<tr><th>Username:</th><td><input name="name" type="text" value="class" /></td></tr>'
+
Accessing "clean" data
----------------------