Django package to serve a single-page app (SPA).
The following settings that make serving SPAs easier are handled in django-spa:
- index.html served when
/
requested - all
/static/…
files served on/…
as well - Django's urls still work (Django admin, templates, Django REST framework APIs)
- everything else goes to
/
for frontend routing (e.g. react-router)
For an example of using django-spa to serve a create-react-app frontend that consumes a Django REST framework API, check out generator-django-rest.
As part of setting up django-spa, you also need to set up WhiteNoise, which we'll summarise here.
First, add django-spa
to your requirements.txt
and pip install -r requirements.txt
(or pipenv install django-spa
).
Whitenoise is installed as a dependency, so no need to specify it extra.
Update settings.py with the Whitenoise & django-spa middleware:
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', 'spa.middleware.SPAMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
Disable runserver's static file serving by adding runserver_nostatic
to the top of your INSTALLED_APPS list:
INSTALLED_APPS = [ 'whitenoise.runserver_nostatic', 'django.contrib.staticfiles', # ... ]
Set the django-spa static file storage:
STATICFILES_STORAGE = 'spa.storage.SPAStaticFilesStorage'
You should be good to go!
Used some parts of the solution suggested in this WhiteNoise issue
for serving index.html on /
.
This package was created with Cookiecutter
and the audreyr/cookiecutter-pypackage project template.