C l v r
Lebak Wangi, Kab. Tangerang
Banten, Indonesia

The Power of Django + HTMX Multi Swap

This article provides an overview of how to integrate Django with HTMX and HTMX Multi Swap to build highly responsive, data-driven web applications. It covers the advantages of Django, the challenges in traditional AJAX-based approaches, and how HTMX simplifies dynamic updates with minimal JavaScript.

Introduction

Django can be considered a highly comprehensive web framework. While its performance is not the fastest, it is still efficient enough to prevent users from experiencing sluggish load times. The main advantages of Django, in my opinion, include:

  • Rapid development speed
  • Excellent security
  • Clear code structure
  • A vast range of features

Additionally, Django allows for quick AI integration by simply loading AI models into views (depending on the model) or even enabling dynamic AI that allows training during the production phase (with some performance impact, of course).

Challenges in Building Data-Driven Web Applications

Despite all its advantages, there are still challenges when building a responsive data-driven web application. Some of these include:

  • 01 - Separating multiple endpoints in urls.py and views.py
  • 02 - Making AJAX requests for each template
To address these issues, I introduce HTMX.

What is HTMX?

HTMX is a JavaScript library that simplifies AJAX requests without requiring extensive JavaScript coding. However, using HTMX does not mean you will completely eliminate JavaScript, as complex functionalities still require JavaScript.

HTMX Multi Swap

HTMX Multi Swap is an HTMX extension that enables responses to target multiple IDs or classes, replacing the data on the client side that shares the same IDs or classes.

Integration with Django

Integrating HTMX Multi Swap with Django is straightforward. Follow these steps:

  • 01 - Copy and include the HTMX and HTMX multi-swap extension script into the <head> section of your Django template
  • 02 - Add the hx-ext="multi-swap" attribute inside the <body> tag of your HTML.

Implementation in Django Views

Post

In Django, implementing this is quite simple. You only need to validate whether the request is a POST or GET method. This allows a single endpoint to return two different responses based on the request type.

Use Case: Handling Checkboxes

For checkboxes, HTMX can be applied in the following way:

Post
  • Place the HTMX attribute inside the <form> before the <input> checkbox.
  • Use id as an identifier for each checkbox input.
  • Ensure that csrf_token is included inside the form.

Sending Data to Django Views

Post
Post

To send data to views.py, follow these steps:

  • Include an array of checked checkbox IDs in the request headers.
  • Send the data when the HTMX request is triggered.

Processing Data in Django

Once the request reaches Django’s views.py, you can:

Post
  • 01 - Extract data from the request headers.
  • 02 - Render the page with <div> elements using multi-swap targets.

This approach enables replacing multiple content sections simultaneously.

Optimizing with Django Sessions

To make the process even more efficient, Django sessions can be used to check whether data has changed from the previous request. This helps in reducing unnecessary content updates and improving performance.

Conclusion

By combining Django, HTMX, and HTMX Multi Swap, developers can create highly responsive, data-driven applications with minimal JavaScript and optimized backend performance.

Work Inquiry

s@claverio.com

+62 855-8830-051

Tangerang, Banten

Lebak Wangi, Sepatan Timur, 15520