Lexington has been awarded a grant from Astro, to celebrate. Get a 30% discount. Apply code LEXINGTON30 at checkout.

← Back to all tutorials

How to create a progress-bar with Tailwind CSS and Alpinejs

#_
Published and written on Apr 12 2024 by Michael Andreuzza

A pregress bar, that’s what we are going to build.

Why are progress bars important

When you are building a website, you will probably have to show a progress bar to your users for many different reasons. For example, you might want to show a progress bar to your users when they are uploading a file, or when they are downloading something. Some Use cases:

  • Show a progress bar to your users when they are uploading a file.
  • Show a progress bar to your users when they are downloading something.
  • Show a progress bar to your users when they are processing a form.
  • When reading a blog post, show a progress bar to show long is left to read.

Let’s create the structure

The important parts:

  • x-data="{ progress: 0, interval: null }" is the data that will be used to store the progress value.
  • x-init="() => { interval = setInterval(() => { progress < 100 ? progress += 5 : clearInterval(interval); }, 100); }" is the code that will be executed every 100ms to update the progress value.
  • x-text="progress + '%'" is the code that will be executed to display the progress value.
  • x-bind:style="'width: ' + progress + '%;'" is the code that will be executed to set the width of the progress bar.
<div
 x-data="{ progress: 0, interval: null }"
 x-init="() => { interval = setInterval(() => { progress < 100 ? progress += 5 : clearInterval(interval); }, 100); }">
 <div
   x-text="progress + '%'">
 </div>
 <div>
   <div
     x-bind:style="'width: ' + progress + '%;'"
     >
   </div>
 </div>
</div>

Let’s add some the classes with Tailwind CSS

The important parts:

  • w-full is the width of the container.
  • text-sm text-base-500 is the text color.
  • bg-base-200 is the background color.
  • rounded-full is the border radius.
  • h-2 is the height of the progress bar.
  • transition-all is the transition effect.
  • ease-in-out is the animation effect.
  • duration-500 is the duration of the animation.
  • cursor-pointer is the cursor style.
  • relative is the positioning style.
  • overflow-hidden is the overflow style.
<div
  x-data="{ progress: 0, interval: null }"
  x-init="() => { interval = setInterval(() => { progress < 100 ? progress += 5 : clearInterval(interval); }, 100); }"
  class="w-full">
  <div
    class="text-sm text-base-500"
    x-text="progress + '%'">
  </div>
  <div class="relative h-2 mt-2 bg-base-200 rounded-full">
    <div
      x-bind:style="'width: ' + progress + '%;'"
      class="absolute top-0 left-0 h-full bg-orange-500 rounded-full">
    </div>
  </div>
</div>

Well that was it! You can now use the progress bar in your project.

Conclusion

In this tutorial, we learned how to create a progress bar using Tailwind CSS and Alpine.js. We covered the basics of Tailwind CSS, including its syntax and classes, and how to use them in our progress bar.

/Michael Andreuzza

Did you like this tutorial? Please share it with your friends!

Get access to all themes

Unlock all themes for $199 for forever! Includes lifetime updates, new themes, unlimited projects, and support
— No subscription needed.