DEV Community

Cover image for How to create Tailwind CSS Modal
Sampson Ovuoba for Devwares

Posted on • Originally published at devwares.com on

How to create Tailwind CSS Modal

When building web applications, one of the most important thing a developer must have in mind is user experience. One of the ways a developer can do this is to pay attention to how user interact with his/her applications.

Table of content

  • Introduction
  • What is a modal dialog
  • Prerequisites
  • Add Tailwind CSS to your Project
  • Create the button
  • Adding an overlay effect
  • Create the modal dialog
  • Adding functionality
  • Conclusion

Introduction

In our previous Tailwind CSS tutorial we introduced what Tailwind CSS is, how to install it in our various projects whether you are using react, html or even Laravel.
Today we are going to practice our skills on what we have learned by building a Tailwind CSS Modal dialog.

What is a modal dialog

A modal is simply a pop up window that appears on top of a main content of a web application. Modal dialog always seeks for user interaction. there can also be used to give critical warning to users to prevent errors.
Throughout the Tailwind CSS tutorial we are going to use Tailwind CSS, HTML and JavaScript to build our modal dialog.
The Tailwind CSS modal dialog will look like the image below

Prerequisite

  • Latest version of Tailwind CSS
  • Knowledge of HTML
  • Knowledge of CSS
  • Knowledge of JavaScript

Add Tailwind CSS to your Project

Before we can go on, it is assumed you have Tailwind CSS installed on your system. If you haven’t, you can check out how to do this on our previous tailwind CSS tutorial.
Creating a button
The first step after installation of the tailwind CSS is to link the html to the tailwind CSS like the code below.

Code:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>modal dialog</title>
    <link rel="stylesheet" href="style.css">
</head>
Enter fullscreen mode Exit fullscreen mode

Creating a button

Once your Tailwind CSS stylesheet is correctly linked. We can go ahead to create a simple button first.
To do this, we wrapped our button under a “div” container and added instruction on our page to click on the button. You can see the code below

Code:

<div class="w-80 mx-auto mt-5 p-7">
        <p class="text-2xl font-medium text-gray-800">
            click here to open the modal
        </p>
        <button
            class="bg-purple-500 text-white rounded-md px-8 py-2 text-base font-medium hover:bg-blue-600 
                focus:outline-none focus:ring-2 focus:ring-green-300"
            id="open-btn">
            Open Modal
        </button>
</div>
Enter fullscreen mode Exit fullscreen mode

In the code above, we created the button and styled it with Tailwind CSS styles. Our modal will look like the image below at this point.
Our modal will look like the image below at this point.

Tailwind CSS Modal

Overlap effect

We can go ahead to create an overlap effect. Overlap effect makes sure the user attends to the dialog box first before continuing with the site.

Code:

 <div class="fixed hidden insert-0 bg-gray-600 bg-opacity-50 overflow-y-auto h-full w-full" id="modal">
Enter fullscreen mode Exit fullscreen mode

In the code above, we used some Tailwind CSS style to render an overlap effect on our page.

Creating the modal dialog

We initially stated at the beginning of our tutorial how important the modal dialog is and what it does for the user.
In our case we created a modal dialog that tells the user whether he /she has successfully created an account.

Code:

<div class="relative top-20 mx-auto p-5 border w-96 shadow-lg rounded-md bg-white">
            <div class="mt-3 text-center">
                <div class="mx-auto flex items-center justify-center h-12 w-12 rounded-full bg-purple-100">
                    <svg class="h-6 w-6 text-purple-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"
                        xmlnx="http://www.w.org/2000/svg">

                        <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M5 13l4 4L19 7"></path>
                    </svg>
                </div>
                <h3 class="text-lg leading-6 font-medium text-gray-900">Successfull</h3>
                <div class="mt-2 px-7 py-3">
                    <p class="text-sm text-gray-500">Account has been Successfull registered.</p>
                </div>
                <div class="items-center px-4 py-3">
                    <button id="ok-btn"
                        class="px-4 py-2 bg-purple-500 text-white 
                            text-base font-medium rounded-md w-full 
                            shadow-sm hover:bg-purple-600 focus:outline-none focus:ring-2 focus:ring-purple-300">
                        OK
                    </button>
                </div>
            </div>
        </div>
</div>
Enter fullscreen mode Exit fullscreen mode

In the code above, we first started by styling the head of our modal dialog. We did this by adding classes that will enable us align our elements inside the parent “div”. we went ahead to create child “div” which contained an “svg” element.
Some classes we added to our modal dialog include

  • Text-center which center all the text present
  • Font-medium which changes the font weight to 500
  • Px-4 and py-3 which adds padding of 16px to the y-axis and 8px to the y-axis
  • Focus:ring-2 which creates an outline ring on the button
  • Focus: ring-purple-300 which creates a purple outline ring
  • Hover: bg-purple-600 simply adds a hover effect on the button by changing the background color. We have successfully styled our Tailwind CSS modal dialog. We can now go ahead and add some functionality to our Tailwind CSS modal

Functionality of the Tailwind CSS Modal dialog

We initially added some IDs to the buttons when we were creating the style for the modal dialog and the instruction button.
We are going to go ahead and add functionality to this buttons by first grabbling all our IDs.
You can write the code inside the script tag at the bottom of our page.

Code:

<script>
        let modal = document.getElementById("modal");
        let btn = document.getElementById("open-btn");
        let button = document.getElementById("ok-btn");
</script>
Enter fullscreen mode Exit fullscreen mode

In the code above, we used the “document.getElementById” to grab the IDs we have given to the buttons on our page. We can now make the buttons do what we want. First we want our “open modal” button to open the modal dialog when clicked and our “OK “ button on the Tailwind CSS modal dialog to close when clicked.
To do this we have to create a function for the both button to do this. The functions are written below

Code:

btn.onclick = function () {
            modal.style.display = "block";
        }

        button.onclick = function () {
            modal.style.display = "none";
        }
Enter fullscreen mode Exit fullscreen mode

Moreover, we need the button to close too when the user clicks anywhere on the window. So we are going to create a function that will do this for us

Code:

window.onclick = function (event) {
            if (event.target == modal) {
                modal.style.display = "none";
            }
        }
    </script>
Enter fullscreen mode Exit fullscreen mode

With the code above, our Tailwind CSS modal dialog is ready. It should look like the image below

Tailwind CSS Modal

Conclusion

In our tailwind CSS tutorial today, we went through how to use tailwind CSS to create modal dialog. In the tutorial we walked through the process of creating the modal dialog from its styling to creating their functionality.
These are one of many ways you can practice your skills with Tailwind CSS. I hope you enjoyed the tutorial.

Design and code tailwind CSS websites 3x faster

We created a tool to visually build Tailwind CSS components, prototypes, websites, and web apps. Ship projects faster using an intuitive tailwind builder and editor.Try Windframe out for free.

WINDFRAME

Resources

Top comments (0)