diff --git a/django/newforms/forms.py b/django/newforms/forms.py
index 36dd36fcce4..15b24b39fe7 100644
--- a/django/newforms/forms.py
+++ b/django/newforms/forms.py
@@ -124,6 +124,33 @@ class Form(StrAndUnicode):
output.append(str_hidden)
return u'\n'.join(output)
+ def as_p(self):
+ "Returns this form rendered as HTML
s."
+ top_errors = self.non_field_errors()
+ output, hidden_fields = [], []
+ for name, field in self.fields.items():
+ bf = BoundField(self, field, name)
+ bf_errors = bf.errors # Cache in local variable.
+ if bf.is_hidden:
+ if bf_errors:
+ top_errors.extend(['(Hidden field %s) %s' % (name, e) for e in bf_errors])
+ hidden_fields.append(unicode(bf))
+ else:
+ if bf_errors:
+ output.append(u'
%s
' % bf_errors)
+ output.append(u'
%s %s
' % (bf.label_tag(escape(bf.verbose_name+':')), bf))
+ if top_errors:
+ output.insert(0, u'
%s
' % top_errors)
+ if hidden_fields: # Insert any hidden fields in the last
.
+ str_hidden = u''.join(hidden_fields)
+ if output:
+ last_td = output[-1]
+ # Chop off the trailing '
' and insert the hidden fields.
+ output[-1] = last_td[:-4] + str_hidden + ''
+ else: # If there aren't any '
's in the output, just append the hidden fields.
+ output.append(str_hidden)
+ return u'\n'.join(output)
+
def non_field_errors(self):
"""
Returns an ErrorList of errors that aren't associated with a particular
diff --git a/tests/regressiontests/forms/tests.py b/tests/regressiontests/forms/tests.py
index 16e56a82129..779db975288 100644
--- a/tests/regressiontests/forms/tests.py
+++ b/tests/regressiontests/forms/tests.py
@@ -1368,6 +1368,13 @@ False
This field is required.
First name:
This field is required.
Last name:
This field is required.
Birthday:
+>>> print p.as_p()
+
This field is required.
+
First name:
+
This field is required.
+
Last name:
+
This field is required.
+
Birthday:
If you don't pass any values to the Form's __init__(), or if you pass None,
the Form won't do any validation. Form.errors will be an empty dictionary *but*
@@ -1389,6 +1396,10 @@ False
First name:
Last name:
Birthday:
+>>> print p.as_p()
+
First name:
+
Last name:
+
Birthday:
Unicode values are handled properly.
>>> p = Person({'first_name': u'John', 'last_name': u'\u0160\u0110\u0106\u017d\u0107\u017e\u0161\u0111', 'birthday': '1940-10-9'})
@@ -1396,6 +1407,8 @@ Unicode values are handled properly.
u'
First name:
\n
Last name:
\n
Birthday:
'
>>> p.as_ul()
u'
First name:
\n
Last name:
\n
Birthday:
'
+>>> p.as_p()
+u'
First name:
\n
Last name:
\n
Birthday:
'
>>> p = Person({'last_name': u'Lennon'})
>>> p.errors
@@ -1432,14 +1445,18 @@ If it's a string that contains '%s', Django will use that as a format string
into which the field's name will be inserted. It will also put a