mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[3.1.x] Fixed #29336 -- Doc'd circular template inheritance
Backport of 2c2f4b3799 from master
			
			
This commit is contained in:
		
				
					committed by
					
						 Carlton Gibson
						Carlton Gibson
					
				
			
			
				
	
			
			
			
						parent
						
							1c3d3294c1
						
					
				
				
					commit
					b81cdaf20d
				
			| @@ -97,3 +97,43 @@ then your directory structure will look like: | ||||
|  | ||||
| With :setting:`APP_DIRS<TEMPLATES-APP_DIRS>` set to ``True``, the template | ||||
| loader will look in the app's templates directory and find the templates. | ||||
|  | ||||
| .. _extending_an_overridden_template: | ||||
|  | ||||
| Extending an overridden template | ||||
| ================================ | ||||
|  | ||||
| With your template loaders configured, you can extend a template using the | ||||
| :ttag:`{% extends %}<extends>` template tag whilst at the same time overriding | ||||
| it. This can allow you to make small customizations without needing to | ||||
| reimplement the entire template. | ||||
|  | ||||
| For example, you can use this technique to add a custom logo to the | ||||
| ``admin/base_site.html`` template: | ||||
|  | ||||
|     .. code-block:: html+django | ||||
|        :caption: templates/admin/base_site.html | ||||
|  | ||||
|         {% extends "admin/base_site.html" %} | ||||
|  | ||||
|         {% block branding %} | ||||
|             <img src="link/to/logo.png" alt="logo"> | ||||
|             {{ block.super }} | ||||
|         {% endblock %} | ||||
|  | ||||
| Key points to note: | ||||
|  | ||||
| * The example creates a file at ``templates/admin/base_site.html`` that uses | ||||
|   the configured project-level ``templates`` directory to override | ||||
|   ``admin/base_site.html``. | ||||
| * The new template extends ``admin/base_site.html``, which is the same template | ||||
|   as is being overridden. | ||||
| * The template replaces just the ``branding`` block, adding a custom logo, and | ||||
|   using ``block.super`` to retain the prior content. | ||||
| * The rest of the template is inherited unchanged from | ||||
|   ``admin/base_site.html``. | ||||
|  | ||||
| This technique works because the template loader does not consider the already | ||||
| loaded override template (at ``templates/admin/base_site.html``) when | ||||
| resolving the ``extends`` tag. Combined with ``block.super`` it is a powerful | ||||
| technique to make small customizations. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user