Use of Django's static templatetag in css file to set a background image
Overview
Setting an image as a background property in CSS can be a problem in
Django as it recommends to refer to your static files with the
static
template tag, but then you realize load_static
doesn’t work
from CSS files.
So how do you do something like background-image: url({% static 'images/cover.jpg' %});
in CSS?
Here are two approaches to solve this issue.
Concept
There is a special setting that handles how static files are served: STATIC_URL.
The static
(django.templatetags.dostatic
) templatetag, joins the
given path with the above mentioned STATIC_URL
setting.
In most cases the STATIC_URL
settings is /static/
, so you can use
/static/images/bg.jpg
in your CSS as long as this setting doesn’t
change.
Having that in mind you can use it, and if not you can choose to apply
that style in the HTML directly using {% static 'images/bg.jpg' %}
,
that way you are sure it will always use the correct setting and be
accessible.
Solution 1: Background in HTML
One of the approaches is to set the above property as an inline style in the HTML attributes:
<div style="background-image: url({% static 'images/cover.jpg' %});">
<!-- image -->
</div>
Solution 2: Static path
In CSS, for example myapp/css/static.css
:
cover {
background: url('/static/img/home-cover.jpg');
}
In HTML:
<div class="cover">
<!-- image -->
</div>
References
- https://docs.djangoproject.com/en/2.1/howto/static-files/
- https://docs.djangoproject.com/en/2.0/ref/settings/
- August 1, 2023
- How to create a reusable Django app and distribute it with PIP or publish to pypi.orgJune 29, 2021
- How To Serve Multiple Django Applications with uWSGI and Nginx in Ubuntu 20.04October 26, 2020
- How to add favicon to Django in 4 stepsSeptember 3, 2020
- Categories in Django with BreadcrumbsAugust 30, 2020
- How To Migrate From SQLite To PostgreSQL In Django In 3 stepsAugust 28, 2020
- Practical guide to internationalize a Django app in 5 steps.August 24, 2020
- Disable new users singup when using Django's allauth packageSeptember 3, 2019
- How to add ads.txt to Django as requested by Google AdsenseAugust 30, 2019
- Have multiple submit buttons for the same Django formJuly 2, 2019
- Better Testing with Page Object Design in DjangoMay 1, 2019
- Generating slugs automatically in Django without packages - Two easy and solid approachesFebruary 14, 2019
- How to set up Django tests to use a free PostgreSQL database in HerokuFebruary 13, 2019
- Dynamically adding forms to a Django FormSet with an add button using jQueryFebruary 6, 2019
- Use of Django's static templatetag in css file to set a background image
- Activate Django's manage.py commands completion in Bash in 2 stepsJanuary 29, 2019
- Sending Emails with Django using SendGrid in 3 easy stepsJanuary 9, 2019
- Adding Users to Your Django Project With A Custom User ModelSeptember 21, 2018
- Setting Up A Factory For One To Many Relationships In FactoryboyApril 17, 2018
- Generate UML class diagrams from django modelsMarch 24, 2018
- Set Up Ubuntu To Serve A Django Website Step By StepJuly 3, 2017
- Django Project Directory StructureJuly 16, 2016
- How to Have Different Django Settings for Development and Production, and environment isolationJune 10, 2016
- Django OverviewJune 2, 2016
Django Forms
- Adding a Cancel button in Django class-based views, editing views and formsJuly 15, 2019
- Using Django Model Primary Key in Custom Forms THE RIGHT WAYJuly 13, 2019
- Django formset handling with class based views, custom errors and validationJuly 4, 2019
- How To Use Bootstrap 4 In Django FormsMay 25, 2018
- Understanding Django FormsApril 30, 2018
- How To Create A Form In DjangoJuly 29, 2016
Articles
Subcategories
Except as otherwise noted, the content of this page is licensed under CC BY-NC-ND 4.0 . Terms and Policy.
Powered by SimpleIT Hugo Theme
·