Create a blog post card layout with Angular and TailwindCSS

4 min read

In this article, we'll create a blog post card layout using Angular and TailwindCSS and it's utility first pattern.

Video tutorial

If you're more into reading, continue below!

TailwindCSS has been getting a lot of attention nowadays because it saves us from writing custom CSS in our styles and instead relies on adding class names to our HTML.

This makes it very fast to create great looking layouts without writing a single line of CSS!

Our final result will be the following blog post card layout.

Looks good, right? Let's get started then!

Adding TailwindCSS to our Angular app

First, we'll create a new angular 11.2 project and add TailwindCSS to it.

If you're wondering how to do that, I've already covered it in a previous blog post. Click here to go through that!

Once that is done, let's start building the card layout with TailwindCSS!

The main card image section

The first part of the card is the image at the top. It covers the whole card without any padding and should also have a fixed height and width, so that it matches other cards in a grid view.

First, we'll stretch the container to the whole screen and then add a container for the card itself. We're giving the card a fixed width here relative to the screen for now. We've also added a nice rounded edge to the card and a bit of shadow for depth!

<div class="h-screen w-screen flex items-center justify-center">
  <div class="w-2/3 rounded-xl shadow-xl"></div>

Next, let's add the img element with it's styling!

  class="w-full rounded-t-xl h-36 object-cover"

So a couple of things to note here. We're stretching the image to extend to the width of the card while the height is fixed so we can have a uniform card height. We want it rounded as well, but only at the top!

Lastly, we're using object-cover to say that the image should cover the whole of the container. This is so we don't see issues with images of different sizes and aspect ratios (which is common when getting images from APIs).

As a result, we have the following!

Great! Just what we want.

We'll go ahead and add a containing div below this and also add some padding before adding the sections below the image.

<div class="p-6"></div>

The category tag

For the category tag, we'll add a flexbox row and add the category inside of it. Here, we'll mostly be adding some styling to the tag to make it resemble a status chips component.

<div class="flex flex-row">
    class="uppercase text-xs text-yellow-700 bg-yellow-200 px-2 py-1 rounded-xl"

So basically some colors, background and padding. And we've topped it all with a rounded class to make the pill shape!

Great. The category tag looks nice!

Card title and description

So let's move on to the card title. Nothing much here, except for some font size and style changes. And a bit of margin to give some space!

<h2 class="text-2xl mt-2 font-bold">The Road to Freedom</h2>

For the card description, it's pretty much the same, except for smaller font sizes and a bit of a darker gray color, instead of black. This makes the title pop more and creates a distinction between the title and the description.

<p class="mt-2 text-gray-600">
  Freelancing can be a great way to move towards freedom in your life. You can
  work anywhere, everywhere.

We're almost there!

The author section

For the author section, we want the elements to be laid out in a row. So we'll use a flexbox container and add the individual elements inside of it.

<div class="flex flex-row mt-4 items-center">
    class="rounded-full mr-2"
  <div class="font-bold mr-2">John Smith</div>
  <div class="text-gray-400">On October 9, 2020</div>

The image is small as it is (30 pixels) and we make the edges round so it gives a good look! We've added some margins to give spacing to each element. And for the date specifically, we've used a lighter gray color because it is supplementary information and not something we want to give primary focus to.

Great and that's just about it! Let's take a look :)

This image has an empty alt attribute; its file name is image-3.png

Nice and simple, but elegant in design. Best part is the speed at which we could come up with this, without writing a single CSS rule in our styles!


As you can see, TailwindCSS has made building great looking layouts fast and convenient. It may look a bit cluttered in your HTML code, but with the speed with which it allows us to work and the other benefits it brings in reusability of classes etc., I feel it is worth it to use for my apps!

Do you feel the same? Or still on the edge?

Try it yourself and let me know!

Continue to the next part in this series, where I'll convert this card into an Angular component and then a responsive card grid layout - all using TailwindCSS for styling!

Thanks for reading! Bye 😊


Liked this post? You can show your love by buying me a coffee - so I can keep bringing you more posts like this. Thanks in advance! 😊

You may also like...