arrow left
Back to Developer Education

How to Integrate Django-Tailwind Styling in an Application

How to Integrate Django-Tailwind Styling in an Application

Every application requires good styling for more readable content. Over the years, CSS (cascading style sheets) dominated before frameworks came into existence. <!--more--> In this tutorial, we will discuss a better way to style Django applications using a framework called django-tailwind. This makes use of the tailwind styling classes in Django projects.

Table of contents

Prerequisites

To follow along with this tutorial, you should have:

  • An understanding of the Python programming language.
  • A pre-installed IDE, preferably Visual Studio Code.
  • Python programming language installed.
  • Node.js installed.
  • An understanding of the Django framework.

Project setup

We will start this tutorial by setting up a project structure in Django's way of doing things. First off, we have to design a storage location for the project.

Open your git bash, and type in the following commands:

cd
cd Desktop
mkdir project
cd project

Check the working directory and ensure you are on the Desktop directory. Create a directory called project and navigate to it.

Now, let's make a virtual environment for the project and install the required dependencies as shown below:

python -m venv env
source env/Scripts/activate
pip install django django-tailwind
pip freeze > requirements.txt

We have configured the environment for the project and installed all the dependencies. We are keeping track of the dependencies via the requirements.txt file.

Let's spin up the Django server, install some apps, and add them to the project settings. We will do this by using the code snippet below:

django-admin startproject myprojectapp
python manage.py startapp comment
python manage.py runserver

We have started the myprojectapp project and made the comment app as well. We also started the Django server with the command python manage.py runserver.

If you open your browser to 127.0.0.1:8000, you should confirm with what we have in the image shown below:

First page

Integrating django-tailwind

The django-tailwind framework requires a specialized app that contains all its dependencies. This framework allows us to style the application using tailwind classes in the templates.

But before that, we have to initialize it:

python manage.py tailwind init

The default name to the tailwind app is theme, change it if you like but ensure the name in the settings.py file is changed as well.

Now open the project settings, navigate to the INSTALLED_APPS, and add the snippets below:

'tailwind'
'theme'
'comment'

In addition, it's mandatory to register the app name in the settings.py right below the file and also specify the internal IP address.

TAILWIND_APP_NAME = 'theme'
INTERNAL_IPS = [
    "127.0.0.1",
]

The tailwind dependency also has to be installed. However, installing this will need a node package manager called npm which comes with the node package.

python manage.py tailwind install

In case the installation could not find the npm package on your system, add the snippet below to your settings.py file depending on your operating system.

If your operating system is either Linux or MacOs, add the snippet below:

NPM_BIN_PATH = '/usr/local/bin/npm'

Otherwise, this works for Windows operating system:

NPM_BIN_PATH = r"C:\Program Files\nodejs\npm.cmd"

In addition to that, we have to add a library that takes care of automatic page refreshing for the styling to take effect in the development phase. Add the line below to the INSTALLED_APPS inside the settings.py file.

'django_browser_reload'

Add the code below into the middleware of the same settings file. It will insert the script tag on every HTML response in case DEBUG is turned True.

"django_browser_reload.middleware.BrowserReloadMiddleware",

Making route for the project

Next, we have to make a route for the middleware added in the root urls.py. This route will automate the reloading of the browser for the styling to take effect.

Now copy the snippet below and add it to the urlpatterns list inside the root URL file.

Add the include parameter to the django.urls import path command.

path("__reload__/", include("django_browser_reload.urls")),

Let's configure the routing for the index page.

We made an app called comment earlier. Open the folder and create the urls.py file then paste the following code into it:

from django.urls import path
from.  import views

urlpatterns = [
    path('', views.homepage, name="index")
]

Next, navigate to the urls.py in the root folder and add the file made above to the URL patterns list. This will allow the root to keep track of URLs matching the app.

path('', include('comment.urls')),

Views for the project

Let's make the first views for the comment app. We will achieve this by using a simple functional view named index based on what we used in the route.

Open the views.py file inside the comment app and type the following:

from django.shortcuts import render

# Create your views here.

def homepage(request):
    return render(request, 'base.html')

The base.html file can be found at the theme/templates/base.html directory.

Finally, start the development server using the commands below in a separate terminal.

python manage.py tailwind start
python manage.py runserver

Open the 127.0.0.1:8000 address and confirm the image below as the first page of the django-tailwind framework.

Django Tailwind

Conclusion

In this tutorial, we have integrated the framework django-tailwind purposely for styling our Django application. Following this tutorial, you can style any Django app by writing the tailwind classes in the HTML syntax.

Happy coding!


Peer Review Contributions by: Dawe Daniel

Published on: Feb 25, 2022
Updated on: Jul 12, 2024
CTA

Cloudzilla is FREE for React and Node.js projects

Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
Get Started for Free