Fixed #1653 -- added some documentation for FileFields/ImageFields. Thanks, Asmodai.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@3466 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Jacob Kaplan-Moss 2006-07-27 23:59:35 +00:00
parent 847b1ed54e
commit 09912cce70
1 changed files with 30 additions and 0 deletions

View File

@ -405,6 +405,36 @@ Here's a simple function that might drive the above form::
form = forms.FormWrapper(manipulator, new_data, errors) form = forms.FormWrapper(manipulator, new_data, errors)
return render_to_response('contact_form.html', {'form': form}) return render_to_response('contact_form.html', {'form': form})
``FileField``s and ``ImageField``s
==================================
Dealing with for ``FileField`` and ``ImageField`` is a little more
complicated.
First, you'll need to make sure that your ``<form>`` element correctly defines
the ``enctype`` in order to upload files::
<form enctype="multipart/form-data" method="POST" action=".">
Next, you'll need to treat the field in the template slightly differently.
Given a field in the model::
photo = model.ImageField('/path/to/upload/location')
You need to actually display two formfields in the template:
<p><label for="id_photo">Photo:</label> {{ form.photo }}{{ form.photo_file }}</p>
The first bit (``{{ form.photo }}``) displays the currently-selected file,
while the second (``{{ form.photo_file }}``) actually contains the file upload
form field. Thus, at the validation layer you need to check the ``photo_file``
key.
Finally, in the view, make sure to call ``new_data.update(request.FILES)``::
new_data = request.POST.copy()
new_data.update(request.FILES)
Validators Validators
========== ==========