mirror of
				https://github.com/django/django.git
				synced 2025-10-26 17:56:32 +00:00 
			
		
		
		
	 3a45fea083
			
		
	
	
		3a45fea083
		
	
	
	
	
		
			
			Thanks to Mariusz Felisiak for review. Co-authored-by: Demetris Stavrou <demestav@gmail.com> Co-authored-by: Caroline Simpson <github@hoojiboo.com>
		
			
				
	
	
		
			343 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			343 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| =====================
 | |
| Generic editing views
 | |
| =====================
 | |
| 
 | |
| The following views are described on this page and provide a foundation for
 | |
| editing content:
 | |
| 
 | |
| * :class:`django.views.generic.edit.FormView`
 | |
| * :class:`django.views.generic.edit.CreateView`
 | |
| * :class:`django.views.generic.edit.UpdateView`
 | |
| * :class:`django.views.generic.edit.DeleteView`
 | |
| 
 | |
| .. seealso::
 | |
| 
 | |
|     The :doc:`messages framework </ref/contrib/messages>` contains
 | |
|     :class:`~django.contrib.messages.views.SuccessMessageMixin`, which
 | |
|     facilitates presenting messages about successful form submissions.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     Some of the examples on this page assume that an ``Author`` model has been
 | |
|     defined as follows in ``myapp/models.py``::
 | |
| 
 | |
|         from django.db import models
 | |
|         from django.urls import reverse
 | |
| 
 | |
|         class Author(models.Model):
 | |
|             name = models.CharField(max_length=200)
 | |
| 
 | |
|             def get_absolute_url(self):
 | |
|                 return reverse('author-detail', kwargs={'pk': self.pk})
 | |
| 
 | |
| ``FormView``
 | |
| ============
 | |
| 
 | |
| .. class:: django.views.generic.edit.FormView
 | |
| 
 | |
|     A view that displays a form. On error, redisplays the form with validation
 | |
|     errors; on success, redirects to a new URL.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.base.TemplateResponseMixin`
 | |
|     * :class:`django.views.generic.edit.BaseFormView`
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
|     * :class:`django.views.generic.base.View`
 | |
| 
 | |
|     **Example myapp/forms.py**::
 | |
| 
 | |
|         from django import forms
 | |
| 
 | |
|         class ContactForm(forms.Form):
 | |
|             name = forms.CharField()
 | |
|             message = forms.CharField(widget=forms.Textarea)
 | |
| 
 | |
|             def send_email(self):
 | |
|                 # send email using the self.cleaned_data dictionary
 | |
|                 pass
 | |
| 
 | |
|     **Example myapp/views.py**::
 | |
| 
 | |
|         from myapp.forms import ContactForm
 | |
|         from django.views.generic.edit import FormView
 | |
| 
 | |
|         class ContactFormView(FormView):
 | |
|             template_name = 'contact.html'
 | |
|             form_class = ContactForm
 | |
|             success_url = '/thanks/'
 | |
| 
 | |
|             def form_valid(self, form):
 | |
|                 # This method is called when valid form data has been POSTed.
 | |
|                 # It should return an HttpResponse.
 | |
|                 form.send_email()
 | |
|                 return super().form_valid(form)
 | |
| 
 | |
|     **Example myapp/contact.html**:
 | |
| 
 | |
|     .. code-block:: html+django
 | |
| 
 | |
|         <form method="post">{% csrf_token %}
 | |
|             {{ form.as_p }}
 | |
|             <input type="submit" value="Send message">
 | |
|         </form>
 | |
| 
 | |
| .. class:: django.views.generic.edit.BaseFormView
 | |
| 
 | |
|     A base view for displaying a form. It is not intended to be used directly,
 | |
|     but rather as a parent class of the
 | |
|     :class:`django.views.generic.edit.FormView` or other views displaying a
 | |
|     form.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
| 
 | |
| ``CreateView``
 | |
| ==============
 | |
| 
 | |
| .. class:: django.views.generic.edit.CreateView
 | |
| 
 | |
|     A view that displays a form for creating an object, redisplaying the form
 | |
|     with validation errors (if there are any) and saving the object.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.detail.SingleObjectTemplateResponseMixin`
 | |
|     * :class:`django.views.generic.base.TemplateResponseMixin`
 | |
|     * :class:`django.views.generic.edit.BaseCreateView`
 | |
|     * :class:`django.views.generic.edit.ModelFormMixin`
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.detail.SingleObjectMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
|     * :class:`django.views.generic.base.View`
 | |
| 
 | |
|     **Attributes**
 | |
| 
 | |
|     .. attribute:: template_name_suffix
 | |
| 
 | |
|         The ``CreateView`` page displayed to a ``GET`` request uses a
 | |
|         ``template_name_suffix`` of ``'_form'``. For
 | |
|         example, changing this attribute to ``'_create_form'`` for a view
 | |
|         creating objects for the example ``Author`` model would cause the
 | |
|         default ``template_name`` to be ``'myapp/author_create_form.html'``.
 | |
| 
 | |
|     .. attribute:: object
 | |
| 
 | |
|         When using ``CreateView`` you have access to ``self.object``, which is
 | |
|         the object being created. If the object hasn't been created yet, the
 | |
|         value will be ``None``.
 | |
| 
 | |
|     **Example myapp/views.py**::
 | |
| 
 | |
|         from django.views.generic.edit import CreateView
 | |
|         from myapp.models import Author
 | |
| 
 | |
|         class AuthorCreateView(CreateView):
 | |
|             model = Author
 | |
|             fields = ['name']
 | |
| 
 | |
|     **Example myapp/author_form.html**:
 | |
| 
 | |
|     .. code-block:: html+django
 | |
| 
 | |
|         <form method="post">{% csrf_token %}
 | |
|             {{ form.as_p }}
 | |
|             <input type="submit" value="Save">
 | |
|         </form>
 | |
| 
 | |
| .. class:: django.views.generic.edit.BaseCreateView
 | |
| 
 | |
|     A base view for creating a new object instance. It is not intended to be
 | |
|     used directly, but rather as a parent class of the
 | |
|     :class:`django.views.generic.edit.CreateView`.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.edit.ModelFormMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
| 
 | |
|     **Methods**
 | |
| 
 | |
|     .. method:: get(request, *args, **kwargs)
 | |
| 
 | |
|         Sets the current object instance (``self.object``) to ``None``.
 | |
| 
 | |
|     .. method:: post(request, *args, **kwargs)
 | |
| 
 | |
|         Sets the current object instance (``self.object``) to ``None``.
 | |
| 
 | |
| ``UpdateView``
 | |
| ==============
 | |
| 
 | |
| .. class:: django.views.generic.edit.UpdateView
 | |
| 
 | |
|     A view that displays a form for editing an existing object, redisplaying
 | |
|     the form with validation errors (if there are any) and saving changes to
 | |
|     the object. This uses a form automatically generated from the object's
 | |
|     model class (unless a form class is manually specified).
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.detail.SingleObjectTemplateResponseMixin`
 | |
|     * :class:`django.views.generic.base.TemplateResponseMixin`
 | |
|     * :class:`django.views.generic.edit.BaseUpdateView`
 | |
|     * :class:`django.views.generic.edit.ModelFormMixin`
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.detail.SingleObjectMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
|     * :class:`django.views.generic.base.View`
 | |
| 
 | |
|     **Attributes**
 | |
| 
 | |
|     .. attribute:: template_name_suffix
 | |
| 
 | |
|         The ``UpdateView`` page displayed to a ``GET`` request uses a
 | |
|         ``template_name_suffix`` of ``'_form'``. For
 | |
|         example, changing this attribute to ``'_update_form'`` for a view
 | |
|         updating objects for the example ``Author`` model would cause the
 | |
|         default ``template_name`` to be ``'myapp/author_update_form.html'``.
 | |
| 
 | |
|     .. attribute:: object
 | |
| 
 | |
|         When using ``UpdateView`` you have access to ``self.object``, which is
 | |
|         the object being updated.
 | |
| 
 | |
|     **Example myapp/views.py**::
 | |
| 
 | |
|         from django.views.generic.edit import UpdateView
 | |
|         from myapp.models import Author
 | |
| 
 | |
|         class AuthorUpdateView(UpdateView):
 | |
|             model = Author
 | |
|             fields = ['name']
 | |
|             template_name_suffix = '_update_form'
 | |
| 
 | |
|     **Example myapp/author_update_form.html**:
 | |
| 
 | |
|     .. code-block:: html+django
 | |
| 
 | |
|         <form method="post">{% csrf_token %}
 | |
|             {{ form.as_p }}
 | |
|             <input type="submit" value="Update">
 | |
|         </form>
 | |
| 
 | |
| .. class:: django.views.generic.edit.BaseUpdateView
 | |
| 
 | |
|     A base view for updating an existing object instance. It is not intended to
 | |
|     be used directly, but rather as a parent class of the
 | |
|     :class:`django.views.generic.edit.UpdateView`.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.edit.ModelFormMixin`
 | |
|     * :class:`django.views.generic.edit.ProcessFormView`
 | |
| 
 | |
|     **Methods**
 | |
| 
 | |
|     .. method:: get(request, *args, **kwargs)
 | |
| 
 | |
|         Sets the current object instance (``self.object``).
 | |
| 
 | |
|     .. method:: post(request, *args, **kwargs)
 | |
| 
 | |
|         Sets the current object instance (``self.object``).
 | |
| 
 | |
| ``DeleteView``
 | |
| ==============
 | |
| 
 | |
| .. class:: django.views.generic.edit.DeleteView
 | |
| 
 | |
|     A view that displays a confirmation page and deletes an existing object.
 | |
|     The given object will only be deleted if the request method is ``POST``. If
 | |
|     this view is fetched via ``GET``, it will display a confirmation page that
 | |
|     should contain a form that POSTs to the same URL.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.detail.SingleObjectTemplateResponseMixin`
 | |
|     * :class:`django.views.generic.base.TemplateResponseMixin`
 | |
|     * :class:`django.views.generic.edit.BaseDeleteView`
 | |
|     * :class:`django.views.generic.edit.DeletionMixin`
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.base.ContextMixin`
 | |
|     * :class:`django.views.generic.detail.BaseDetailView`
 | |
|     * :class:`django.views.generic.detail.SingleObjectMixin`
 | |
|     * :class:`django.views.generic.base.View`
 | |
| 
 | |
|     **Attributes**
 | |
| 
 | |
|     .. attribute:: form_class
 | |
| 
 | |
|         .. versionadded:: 4.0
 | |
| 
 | |
|         Inherited from :class:`~django.views.generic.edit.BaseDeleteView`. The
 | |
|         form class that will be used to confirm the request. By default
 | |
|         :class:`django.forms.Form`, resulting in an empty form that is always
 | |
|         valid.
 | |
| 
 | |
|         By providing your own ``Form`` subclass, you can add additional
 | |
|         requirements, such as a confirmation checkbox, for example.
 | |
| 
 | |
|     .. attribute:: template_name_suffix
 | |
| 
 | |
|         The ``DeleteView`` page displayed to a ``GET`` request uses a
 | |
|         ``template_name_suffix`` of ``'_confirm_delete'``. For
 | |
|         example, changing this attribute to ``'_check_delete'`` for a view
 | |
|         deleting objects for the example ``Author`` model would cause the
 | |
|         default ``template_name`` to be ``'myapp/author_check_delete.html'``.
 | |
| 
 | |
|     **Example myapp/views.py**::
 | |
| 
 | |
|         from django.urls import reverse_lazy
 | |
|         from django.views.generic.edit import DeleteView
 | |
|         from myapp.models import Author
 | |
| 
 | |
|         class AuthorDeleteView(DeleteView):
 | |
|             model = Author
 | |
|             success_url = reverse_lazy('author-list')
 | |
| 
 | |
|     **Example myapp/author_confirm_delete.html**:
 | |
| 
 | |
|     .. code-block:: html+django
 | |
| 
 | |
|         <form method="post">{% csrf_token %}
 | |
|             <p>Are you sure you want to delete "{{ object }}"?</p>
 | |
|             {{ form }}
 | |
|             <input type="submit" value="Confirm">
 | |
|         </form>
 | |
| 
 | |
| .. class:: django.views.generic.edit.BaseDeleteView
 | |
| 
 | |
|     A base view for deleting an object instance. It is not intended to be used
 | |
|     directly, but rather as a parent class of the
 | |
|     :class:`django.views.generic.edit.DeleteView`.
 | |
| 
 | |
|     **Ancestors (MRO)**
 | |
| 
 | |
|     This view inherits methods and attributes from the following views:
 | |
| 
 | |
|     * :class:`django.views.generic.edit.DeletionMixin`
 | |
|     * :class:`django.views.generic.edit.FormMixin`
 | |
|     * :class:`django.views.generic.detail.BaseDetailView`
 | |
| 
 | |
|     .. versionchanged:: 4.0
 | |
| 
 | |
|         In older versions, ``BaseDeleteView`` does not inherit from
 | |
|         ``FormMixin``.
 |