mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Specifically in rendering shortcuts, template responses, and class-based views that return template responses. Also added a test for render_to_response(status=...) which was missing fromfdbfc980. Thanks Tim and Carl for the review. Backport of2133f31from master. Conflicts: docs/topics/http/shortcuts.txt tests/generic_views/test_base.py
		
			
				
	
	
		
			112 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| =============
 | |
| Simple mixins
 | |
| =============
 | |
| 
 | |
| ContextMixin
 | |
| ------------
 | |
| 
 | |
| .. class:: django.views.generic.base.ContextMixin
 | |
| 
 | |
|     **Methods**
 | |
| 
 | |
|     .. method:: get_context_data(**kwargs)
 | |
| 
 | |
|         Returns a dictionary representing the template context. The keyword
 | |
|         arguments provided will make up the returned context. Example usage::
 | |
| 
 | |
|             def get_context_data(self, **kwargs):
 | |
|                 context = super(RandomNumberView, self).get_context_data(**kwargs)
 | |
|                 context['number'] = random.randrange(1, 100)
 | |
|                 return context
 | |
| 
 | |
|         The template context of all class-based generic views include a
 | |
|         ``view`` variable that points to the ``View`` instance.
 | |
| 
 | |
|         .. admonition:: Use ``alters_data`` where appropriate
 | |
| 
 | |
|             Note that having the view instance in the template context may
 | |
|             expose potentially hazardous methods to template authors.  To
 | |
|             prevent methods like this from being called in the template, set
 | |
|             ``alters_data=True`` on those methods.  For more information, read
 | |
|             the documentation on :ref:`rendering a template context
 | |
|             <alters-data-description>`.
 | |
| 
 | |
| TemplateResponseMixin
 | |
| ---------------------
 | |
| 
 | |
| .. class:: django.views.generic.base.TemplateResponseMixin
 | |
| 
 | |
|     Provides a mechanism to construct a
 | |
|     :class:`~django.template.response.TemplateResponse`, given
 | |
|     suitable context. The template to use is configurable and can be
 | |
|     further customized by subclasses.
 | |
| 
 | |
|     **Attributes**
 | |
| 
 | |
|     .. attribute:: template_name
 | |
| 
 | |
|         The full name of a template to use as defined by a string. Not defining
 | |
|         a ``template_name`` will raise a
 | |
|         :class:`django.core.exceptions.ImproperlyConfigured` exception.
 | |
| 
 | |
|     .. attribute:: template_engine
 | |
| 
 | |
|         .. versionadded:: 1.8
 | |
| 
 | |
|         The :setting:`NAME <TEMPLATES-NAME>` of a template engine to use for
 | |
|         loading the template. ``template_engine`` is passed as the ``using``
 | |
|         keyword argument to ``response_class``. Default is ``None``, which
 | |
|         tells Django to search for the template in all configured engines.
 | |
| 
 | |
|     .. attribute:: response_class
 | |
| 
 | |
|         The response class to be returned by ``render_to_response`` method.
 | |
|         Default is
 | |
|         :class:`TemplateResponse <django.template.response.TemplateResponse>`.
 | |
|         The template and context of ``TemplateResponse`` instances can be
 | |
|         altered later (e.g. in
 | |
|         :ref:`template response middleware <template-response-middleware>`).
 | |
| 
 | |
|         .. versionchanged:: 1.8
 | |
| 
 | |
|             In older versions of Django, ``TemplateResponse`` used
 | |
|             :class:`~django.template.RequestContext` in such a way that values
 | |
|             from template context processors would override template variables
 | |
|             defined in your views. For example, if you subclassed
 | |
|             :class:`DetailView <django.views.generic.detail.DetailView>` and
 | |
|             set ``context_object_name`` to ``user``, the
 | |
|             ``django.contrib.auth.context_processors.auth`` context processor
 | |
|             would overwrite your variable with the current user. Now, for
 | |
|             consistency with the ``render()`` shortcut, values in the context
 | |
|             provided by the class override values from context processors.
 | |
| 
 | |
|         If you need custom template loading or custom context object
 | |
|         instantiation, create a ``TemplateResponse`` subclass and assign it to
 | |
|         ``response_class``.
 | |
| 
 | |
|     .. attribute:: content_type
 | |
| 
 | |
|         The content type to use for the response. ``content_type`` is passed
 | |
|         as a keyword argument to ``response_class``. Default is ``None`` --
 | |
|         meaning that Django uses :setting:`DEFAULT_CONTENT_TYPE`.
 | |
| 
 | |
|     **Methods**
 | |
| 
 | |
|     .. method:: render_to_response(context, **response_kwargs)
 | |
| 
 | |
|         Returns a ``self.response_class`` instance.
 | |
| 
 | |
|         If any keyword arguments are provided, they will be passed to the
 | |
|         constructor of the response class.
 | |
| 
 | |
|         Calls :meth:`get_template_names()` to obtain the list of template names
 | |
|         that will be searched looking for an existent template.
 | |
| 
 | |
|     .. method:: get_template_names()
 | |
| 
 | |
|         Returns a list of template names to search for when rendering the
 | |
|         template.
 | |
| 
 | |
|         If :attr:`template_name` is specified, the default implementation will
 | |
|         return a list containing :attr:`template_name` (if it is specified).
 |