Published on

The 5 Really Obvious Ways To Create A Modern Music Player Cards With Tailwind CSS Better That You Ever Did

Modern Music Player Cards

In the world of FrontEnd development, CSS frameworks have become an essential tool for developers to create responsive and visually appealing UI components. Tailwind CSS is one such framework that has gained popularity in recent years due to its unique approach to styling. In this article, we will explore how to create a Modern Music Player Cards UI component using Tailwind CSS.

What is Tailwind CSS?

Tailwind CSS is a utility-first CSS framework that provides pre-defined classes for styling HTML elements. It allows developers to create custom designs by combining these classes in a modular way. Unlike other CSS frameworks, Tailwind CSS does not have pre-designed components, which gives developers more flexibility to create unique designs.

The description of Modern Music Player Cards UI component

A Modern Music Player Cards UI component is a card-based design that displays information about a music track or album. It typically includes an image of the album cover, the name of the artist, the name of the track, and playback controls. This UI component is commonly used in music streaming applications and websites.

Why use Tailwind CSS to create a Modern Music Player Cards UI component?

Tailwind CSS provides a simple and efficient way to create responsive UI components. It allows developers to write less code and focus more on the design. Tailwind CSS also provides a wide range of pre-defined classes that can be used to style different elements of the UI component. This makes it easier for developers to create a consistent design across different devices and screen sizes.

The preview of Modern Music Player Cards UI component

To create a Modern Music Player Cards UI component using Tailwind CSS, we will use a card-based design with an image of the album cover, the name of the artist, the name of the track, and playback controls.

Free download of the Modern Music Player Cards's source code

The source code of Modern Music Player Cards UI component

To create a Modern Music Player Cards UI component using Tailwind CSS, we will use HTML and CSS.

<main class="grid place-items-center min-h-screen bg-gradient-to-t from-blue-200 to-gray-800 p-5">
  <div>
    <h1 class="text-4xl sm:text-5xl md:text-7xl font-bold text-gray-200 mb-5">Top Beats</h1>
    <section class="grid grid-cols-1 sm:grid-cols-3 gap-4">
      <!-- CARD 1 -->
     
      <!-- END OF CARD 1 -->
      <div class="bg-gray-800 w-60 shadow-lg rounded p-2">
        <div class="py-2 px-4 text-center tracking-wide grid grid-cols-3 gap-6">
            <div class="flex tools">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4.318 6.318a4.5 4.5 0 000 6.364L12 20.364l7.682-7.682a4.5 4.5 0 00-6.364-6.364L12 7.636l-1.318-1.318a4.5 4.5 0 00-6.364 0z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">324</p>
            
            </div>
            <div class="flex followers">
                 <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 12h.01M12 12h.01M16 12h.01M21 12c0 4.418-4.03 8-9 8a9.863 9.863 0 01-4.255-.949L3 20l1.395-3.72C3.512 15.042 3 13.574 3 12c0-4.418 4.03-8 9-8s9 3.582 9 8z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">7542</p>
              
            </div>
            <div class="flex following">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 16v1a3 3 0 003 3h10a3 3 0 003-3v-1m-4-4l-4 4m0 0l-4-4m4 4V4" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">295</p>
            
            </div>
        </div>
        <div class="group relative">
              <img alt="Placeholder" class="block h-48 w-full rounded"  src="">
          <div class="absolute bg-black rounded bg-opacity-0 group-hover:bg-opacity-60 w-full h-full top-0 flex items-center group-hover:opacity-100 duration-700 transition justify-evenly">
            
            <button class="hover:scale-110 text-white outline-none  opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-heart" viewBox="0 0 16 16">
                <path d="M8 2.748l-.717-.737C5.6.281 2.514.878 1.4 3.053c-.523 1.023-.641 2.5.314 4.385.92 1.815 2.834 3.989 6.286 6.357 3.452-2.368 5.365-4.542 6.286-6.357.955-1.886.838-3.362.314-4.385C13.486.878 10.4.28 8.717 2.01L8 2.748zM8 15C-7.333 4.868 3.279-3.04 7.824 1.143c.06.055.119.112.176.171a3.12 3.12 0 0 1 .176-.17C12.72-3.042 23.333 4.867 8 15z" />
              </svg>
            </button>

            <button  @click="play_single(this.instru)" class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg v-if="this.is_playing == false" xmlns="http://www.w3.org/2000/svg" width="40" height="40" fill="currentColor" class="bi bi-play-circle-fill" viewBox="0 0 16 16">
                <path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z" />
              </svg>
            </button>

            <button class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-three-dots" viewBox="0 0 16 16">
                <path d="M3 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z" />
              </svg>
            </button>
          </div>
        </div>
        <div class="p-2">
            <h3 class=" text-white py-1 text-base justify-center">First instru</h3>
            <p class="text-gray-400 text-sm">By @jordi_248</p>
    
        </div>
      </div>

      <!-- CARD 2 -->
      <div class="bg-gray-800 w-60 shadow-lg rounded p-2">
        <div class="py-2 px-4 text-center tracking-wide grid grid-cols-3 gap-6">
            <div class="flex tools">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4.318 6.318a4.5 4.5 0 000 6.364L12 20.364l7.682-7.682a4.5 4.5 0 00-6.364-6.364L12 7.636l-1.318-1.318a4.5 4.5 0 00-6.364 0z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">34</p>
            
            </div>
            <div class="flex followers">
                 <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 12h.01M12 12h.01M16 12h.01M21 12c0 4.418-4.03 8-9 8a9.863 9.863 0 01-4.255-.949L3 20l1.395-3.72C3.512 15.042 3 13.574 3 12c0-4.418 4.03-8 9-8s9 3.582 9 8z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">752</p>
              
            </div>
            <div class="flex following">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 16v1a3 3 0 003 3h10a3 3 0 003-3v-1m-4-4l-4 4m0 0l-4-4m4 4V4" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">95</p>
            
            </div>
        </div>
        <div class="group relative">
              <img alt="Placeholder" class="block h-48 w-full rounded"  src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcThLlG6aaZ1G7Gvb6n3ncqWuNS77VmmhlXunQ&usqp=CAU">
          <div class="absolute bg-black rounded bg-opacity-0 group-hover:bg-opacity-60 w-full h-full top-0 flex items-center group-hover:opacity-100 duration-700 transition justify-evenly">
            
            <button class="hover:scale-110 text-white outline-none  opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-heart" viewBox="0 0 16 16">
                <path d="M8 2.748l-.717-.737C5.6.281 2.514.878 1.4 3.053c-.523 1.023-.641 2.5.314 4.385.92 1.815 2.834 3.989 6.286 6.357 3.452-2.368 5.365-4.542 6.286-6.357.955-1.886.838-3.362.314-4.385C13.486.878 10.4.28 8.717 2.01L8 2.748zM8 15C-7.333 4.868 3.279-3.04 7.824 1.143c.06.055.119.112.176.171a3.12 3.12 0 0 1 .176-.17C12.72-3.042 23.333 4.867 8 15z" />
              </svg>
            </button>

            <button  @click="play_single(this.instru)" class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg v-if="this.is_playing == false" xmlns="http://www.w3.org/2000/svg" width="40" height="40" fill="currentColor" class="bi bi-play-circle-fill" viewBox="0 0 16 16">
                <path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z" />
              </svg>
            </button>

            <button class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-three-dots" viewBox="0 0 16 16">
                <path d="M3 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z" />
              </svg>
            </button>
          </div>
        </div>
        <div class="p-2">
            <h3 class=" text-white py-1 text-base justify-center">Second instru</h3>
            <p class="text-gray-400 text-sm">By @jordi_248</p>
    
        </div>
      </div>
      <!-- END OF CARD 2 -->

      <!-- CARD 3 -->
       <div class="bg-gray-800 w-60 shadow-lg rounded p-2">
        <div class="py-2 px-4 text-center tracking-wide grid grid-cols-3 gap-6">
            <div class="flex tools">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4.318 6.318a4.5 4.5 0 000 6.364L12 20.364l7.682-7.682a4.5 4.5 0 00-6.364-6.364L12 7.636l-1.318-1.318a4.5 4.5 0 00-6.364 0z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">348</p>
            
            </div>
            <div class="flex followers">
                 <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M8 12h.01M12 12h.01M16 12h.01M21 12c0 4.418-4.03 8-9 8a9.863 9.863 0 01-4.255-.949L3 20l1.395-3.72C3.512 15.042 3 13.574 3 12c0-4.418 4.03-8 9-8s9 3.582 9 8z" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">52</p>
              
            </div>
            <div class="flex following">
                <p class="flex text-gray-400 text-sm justify-center">
                  <svg xmlns="http://www.w3.org/2000/svg" class="h-5 w-5" fill="none" viewBox="0 0 24 24" stroke="currentColor">
                    <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 16v1a3 3 0 003 3h10a3 3 0 003-3v-1m-4-4l-4 4m0 0l-4-4m4 4V4" />
                  </svg>
                </p>
                <p class="text-sm text-gray-50 animate-pulse px-2">995</p>
            
            </div>
        </div>
        <div class="group relative">
              <img alt="Placeholder" class="block h-48 w-full rounded"  src="">
          <div class="absolute bg-black rounded bg-opacity-0 group-hover:bg-opacity-60 w-full h-full top-0 flex items-center group-hover:opacity-100 duration-700 transition justify-evenly">
            
            <button class="hover:scale-110 text-white outline-none  opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-heart" viewBox="0 0 16 16">
                <path d="M8 2.748l-.717-.737C5.6.281 2.514.878 1.4 3.053c-.523 1.023-.641 2.5.314 4.385.92 1.815 2.834 3.989 6.286 6.357 3.452-2.368 5.365-4.542 6.286-6.357.955-1.886.838-3.362.314-4.385C13.486.878 10.4.28 8.717 2.01L8 2.748zM8 15C-7.333 4.868 3.279-3.04 7.824 1.143c.06.055.119.112.176.171a3.12 3.12 0 0 1 .176-.17C12.72-3.042 23.333 4.867 8 15z" />
              </svg>
            </button>

            <button  @click="play_single(this.instru)" class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg v-if="this.is_playing == false" xmlns="http://www.w3.org/2000/svg" width="40" height="40" fill="currentColor" class="bi bi-play-circle-fill" viewBox="0 0 16 16">
                <path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM6.79 5.093A.5.5 0 0 0 6 5.5v5a.5.5 0 0 0 .79.407l3.5-2.5a.5.5 0 0 0 0-.814l-3.5-2.5z" />
              </svg>
            </button>

            <button class="hover:scale-110 text-white outline-none opacity-0 transform translate-y-3 group-hover:translate-y-0 group-hover:opacity-100 transition">
              <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-three-dots" viewBox="0 0 16 16">
                <path d="M3 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z" />
              </svg>
            </button>
          </div>
        </div>
        <div class="p-2">
            <h3 class=" text-white py-1 text-base justify-center">Third instru</h3>
            <p class="text-gray-400 text-sm">By @jordi_248</p>
    
        </div>
      </div>
      <!-- END OF CARD 3 -->
    </section>
  </div>
</main>

How to create a Modern Music Player Cards with Tailwind CSS?

To create a Modern Music Player Cards UI component using Tailwind CSS, follow these steps:

Step 1: Set up the HTML structure

The first step is to set up the HTML structure for the UI component. We will use a card-based design with an image of the album cover, the name of the artist, the name of the track, and playback controls.

<div class="card">
  <img src="album-cover.jpg" alt="Album Cover">
  <div class="card-body">
    <h3 class="card-title">Artist Name</h3>
    <p class="card-text">Track Name</p>
    <div class="playback-controls">
      <button class="play-button"></button>
      <button class="pause-button"></button>
      <button class="stop-button"></button>
    </div>
  </div>
</div>

Step 2: Add Tailwind CSS classes

Next, we will add Tailwind CSS classes to style the UI component. We will use the flex and items-center classes to align the image and text vertically. We will also use the rounded-lg class to give the card a rounded border.

<div class="card flex items-center rounded-lg">
  <img src="album-cover.jpg" alt="Album Cover" class="w-32 h-32">
  <div class="card-body ml-4">
    <h3 class="card-title text-xl font-semibold">Artist Name</h3>
    <p class="card-text text-gray-600">Track Name</p>
    <div class="playback-controls mt-4">
      <button class="play-button bg-green-500 hover:bg-green-600 text-white font-bold py-2 px-4 rounded-full mr-2">
        Play
      </button>
      <button class="pause-button bg-yellow-500 hover:bg-yellow-600 text-white font-bold py-2 px-4 rounded-full mr-2">
        Pause
      </button>
      <button class="stop-button bg-red-500 hover:bg-red-600 text-white font-bold py-2 px-4 rounded-full">
        Stop
      </button>
    </div>
  </div>
</div>

Step 3: Add custom styles

Finally, we will add custom styles to enhance the design of the UI component. We will use the hover:bg-green-600 class to change the background color of the play button when the user hovers over it. We will also use the text-gray-600 class to give the track name a lighter color.

<div class="card flex items-center rounded-lg">
  <img src="album-cover.jpg" alt="Album Cover" class="w-32 h-32">
  <div class="card-body ml-4">
    <h3 class="card-title text-xl font-semibold">Artist Name</h3>
    <p class="card-text text-gray-600">Track Name</p>
    <div class="playback-controls mt-4">
      <button class="play-button bg-green-500 hover:bg-green-600 text-white font-bold py-2 px-4 rounded-full mr-2">
        Play
      </button>
      <button class="pause-button bg-yellow-500 hover:bg-yellow-600 text-white font-bold py-2 px-4 rounded-full mr-2">
        Pause
      </button>
      <button class="stop-button bg-red-500 hover:bg-red-600 text-white font-bold py-2 px-4 rounded-full">
        Stop
      </button>
    </div>
  </div>
</div>

Conclusion

In this article, we have explored how to create a Modern Music Player Cards UI component using Tailwind CSS. We have seen how Tailwind CSS provides a simple and efficient way to create responsive UI components. By following the steps outlined in this article, you can create your own custom designs using Tailwind CSS.