Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
django-browser-reload
Advanced tools
.. image:: https://img.shields.io/github/actions/workflow/status/adamchainz/django-browser-reload/main.yml.svg?branch=main&style=for-the-badge :target: https://github.com/adamchainz/django-browser-reload/actions?workflow=CI
.. image:: https://img.shields.io/badge/Coverage-100%25-success?style=for-the-badge :target: https://github.com/adamchainz/django-browser-reload/actions?workflow=CI
.. image:: https://img.shields.io/pypi/v/django-browser-reload.svg?style=for-the-badge :target: https://pypi.org/project/django-browser-reload/
.. image:: https://img.shields.io/badge/code%20style-black-000000.svg?style=for-the-badge :target: https://github.com/psf/black
.. image:: https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white&style=for-the-badge :target: https://github.com/pre-commit/pre-commit :alt: pre-commit
Automatically reload your browser in development.
Work smarter and faster with my book Boost Your Django DX <https://adamchainz.gumroad.com/l/byddx>
__ which covers django-browser-reload and many other tools.
I wrote django-browser-reload whilst working on the book!
Python 3.9 to 3.13 supported.
Django 4.2 to 5.1 supported.
WSGI supported on all Django versions. ASGI supported on Django 4.2+.
Your browser needs to support:
|EventSource|__ - universally available.
.. |EventSource| replace:: EventSource
__ https://developer.mozilla.org/en-US/docs/Web/API/EventSource#browser_compatibility
|SharedWorker|__ - available on Chrome, Edge, Firefox, and Opera for a long time. Available on Safari since version 16 (2022-09-12).
.. |SharedWorker| replace:: SharedWorker
__ https://developer.mozilla.org/en-US/docs/Web/API/SharedWorker#browser_compatibility
Install with pip:
.. code-block:: sh
python -m pip install django-browser-reload
Ensure you have "django.contrib.staticfiles"
in your INSTALLED_APPS
.
Add django-browser-reload to your INSTALLED_APPS
:
.. code-block:: python
INSTALLED_APPS = [
...,
"django_browser_reload",
...,
]
Include the app URLs in your root URLconf:
.. code-block:: python
from django.urls import include, path
urlpatterns = [
...,
path("__reload__/", include("django_browser_reload.urls")),
]
You can use another prefix if required.
Add the middleware:
.. code-block:: python
MIDDLEWARE = [ # ... "django_browser_reload.middleware.BrowserReloadMiddleware", # ... ]
The middleware should be listed after any others that encode the response, such as Django’s GZipMiddleware
.
The middleware automatically inserts the required script tag on HTML responses before </body>
when DEBUG
is True
.
It does so to every HTML response, meaning it will be included on Django’s debug pages, admin pages, etc.
If you want more control, you can instead insert the script tag in your templates—see below.
All done! 📯
For faster and more efficient reloading, also set up Django’s built-in Watchman support <https://adamj.eu/tech/2021/01/20/efficient-reloading-in-djangos-runserver-with-watchman/>
__.
When DEBUG
is True
, the template tag includes a small script.
This script connects back to the development server and will automatically reload when static assets or templates are modified, or after runserver
restarts.
The reload only happens in the most recently opened tab.
See the example project <https://github.com/adamchainz/django-browser-reload/tree/main/example>
__ in the example/
directory of the GitHub repository.
Start it up and modify its files to see the reloading in action.
If the middleware doesn’t work for you, you can also use a template tag to insert the script on relevant pages.
The template tag has both Django templates and Jinja versions, and only outputs the script tag when DEBUG
is True
.
For Django Templates, load the tag and use it in your base template.
The tag can go anywhere, but it’s best just before </body>
:
.. code-block:: html
{% load django_browser_reload %}
...
{% django_browser_reload_script %}
</body>
To add django-browser-reload to Django’s admin, do so in a template called admin/base_site.html
:
.. code-block:: html
{% extends "admin/base_site.html" %}
{% load django_browser_reload %}
{% block extrahead %}
{{ block.super }}
{% django_browser_reload_script %}
{% endblock %}
This follows Django’s documentation on extending an overridden template <https://docs.djangoproject.com/en/4.0/howto/overriding-templates/#extending-an-overridden-template>
__.
For Jinja Templates, you need to perform two steps.
First, load the tag function into the globals of your custom environment <https://docs.djangoproject.com/en/stable/topics/templates/#django.template.backends.jinja2.Jinja2>
__:
.. code-block:: python
# myproject/jinja2.py
from jinja2 import Environment
from django_browser_reload.jinja import django_browser_reload_script
def environment(**options):
env = Environment(**options)
env.globals.update(
{
# ...
"django_browser_reload_script": django_browser_reload_script,
}
)
return env
Second, render the tag in your base template.
It can go anywhere, but it’s best just before </body>
:
.. code-block:: html
...
{{ django_browser_reload_script() }}
</body>
</html>
Ta-da!
Here’s a diagram:
.. code-block:: text
Browser
Tab 1 Tab 2 Tab N
listener listener listener
\ | /
Django \ | /
\ | /
Events View --------------------> Shared worker
The template tag includes a listener script on each page. This listener script starts or connects to a |SharedWorker2|, running a worker script. The worker script then connects to the events view in Django, using an |EventSource2| to receive server-sent events.
.. |SharedWorker2| replace:: SharedWorker
__ https://developer.mozilla.org/en-US/docs/Web/API/SharedWorker
.. |EventSource2| replace:: EventSource
__ https://developer.mozilla.org/en-US/docs/Web/API/EventSource
This event source uses |StreamingHttpResponse|__ to send events to the worker.
The view continues streaming events indefinitely, until disconnected.
(This requires a thread and will not work if you use runserver
\’s |--nothreading option|__.)
.. |--nothreading option| replace:: --nothreading
option
__ https://docs.djangoproject.com/en/stable/ref/django-admin/#cmdoption-runserver-nothreading
On a relevant event, the worker will reload the most recently connected tab. (It avoids reloading all tabs since that could be expensive.)
.. |StreamingHttpResponse| replace:: StreamingHttpResponse
__ https://docs.djangoproject.com/en/stable/ref/request-response/#django.http.StreamingHttpResponse
To reload when a template changes, django-browser-reload piggybacks on Django’s autoreloading infrastructure. An internal Django signal indicates when a template file has changed. The events view receives this signal and sends an event to the worker, which triggers a reload. There is no smart filtering - if any template file changes, the view is reloaded.
To reload when the server restarts, django-browser-reload uses a version ID.
This ID is randomly generated when the view module is imported, so it will be different every time the server starts.
When the server restarts, the worker’s EventSource
reconnects with minimal delay.
On connection, the events view sends the version ID, which the worker sees as different, so it triggers a reload.
The events view also sends the version ID every second to keep the connection alive.
FAQs
Automatically reload your browser in development.
We found that django-browser-reload demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.