data:image/s3,"s3://crabby-images/e8d69/e8d694f62a2ef5a0887e3a075bfb669f25f6a23b" alt=""
block-level elements:<div>
, <p>
, <h1>-<h6>
, <section>
, <article>
inline-level elements:<span>
, <a>
, <strong>
, <em>
block-level elements: one below other block-level elements (default)
<div> <div class="quote">...</div> <div class="quote">...</div> <div class="quote">...</div> </div> | <div class="flex"> <div class="quote">...</div> <div class="quote">...</div> <div class="quote">...</div> </div> |
data:image/s3,"s3://crabby-images/1ec7f/1ec7fb9fa2b97e403868674727e5410a1eedd08b" alt=""
Tailwind class | Explanation |
justify-start | All items are placed at the beginning of the container with no spaces |
justify-end | All items are placed at the end of the container with no spaces |
justify-center | All items are placed at the center with no spaces |
justify-between | All items are spaced out as much as possiblewith first item at the beginning and last item at the end (We just saw this in action) |
justify-around | Space before the flex items and after the flex items are half as much as space between the items |
justify-evenly | Space before, after and between the items are same |
<div class="wrapper">
<div class="menu flex justify-start">...</div>
</div>
<div class="wrapper">
<div class="menu flex justify-end">...</div>
</div>
<div class="wrapper">
<div class="menu flex justify-center">...</div>
</div>
<div class="wrapper">
<div class="menu flex justify-between">...</div>
</div>
<div class="wrapper">
<div class="menu flex justify-around">...</div>
</div>
<div class="wrapper">
<div class="menu flex justify-evenly">...</div>
</div>
data:image/s3,"s3://crabby-images/33096/33096be68b0175ab67a609b41a859bed82f39909" alt=""
<div class="card"> | <div class="card"> |
data:image/s3,"s3://crabby-images/dc316/dc3169c815617020160d442acf2735dd81011223" alt=""
<div class="container"> | <div class="container flex"> |
data:image/s3,"s3://crabby-images/fcfd8/fcfd8581ce01727de886c77c7e8442ee09e66d46" alt=""
<div class="container flex justify-around flex-wrap">
<div class="team-profile">
...
</div>
<div class="team-profile">
...
</div>
<div class="team-profile">
...
</div>
<div class="team-profile">
...
</div>
</div>
data:image/s3,"s3://crabby-images/c67a2/c67a246b97f3a3fde527a56b771fa6e0955d6967" alt=""
<div class="wrapper">
<h2>Top Clients</h2>
<div class="logos flex justify-around flex-wrap">
...
</div>
</div>
data:image/s3,"s3://crabby-images/2db64/2db64e77cb131bd43711ae9f745bef2b0c1d2a87" alt=""
<div class=""> | <div class="flex"> | <div class="flex items-center"> |
data:image/s3,"s3://crabby-images/80558/805588a2cc116f1b3e8a7664e056a8555ad677a3" alt=""
<div class="icon-wrap flex items-center">
<span class="icon">...</span>
<span class="icon-text">...</span>
</div>
data:image/s3,"s3://crabby-images/57a5a/57a5ab224523738cf083db535224691771ac924a" alt=""
Tailwind Class | Explanation |
items-stretch | All items are stretched to fill the container |
items-center | All items are aligned to the center of the container |
items-start | All items are aligned to the beginning of the container |
items-end | All items are aligned to the end of the container |
items-baseline | All items are positioned such that the base aligns to the end of the container |
data:image/s3,"s3://crabby-images/4f010/4f0103a2873b2c5bcf69d9b1687726bca359e933" alt=""
@tailwind base; | <div class="wrapper"> |
data:image/s3,"s3://crabby-images/d9e73/d9e731350a933ccf1bf97218e4d60b87ca3804f8" alt=""
@tailwind base; | <div class="profile flex items-center"> …" alt="" /> |
data:image/s3,"s3://crabby-images/bcb8a/bcb8af8d0e1422f711c62e5270e2e9b5f39ad3f5" alt=""
data:image/s3,"s3://crabby-images/2c546/2c546df4dc5b55701e3153857999c08dd9ade86d" alt=""
There are three block elements in the blue area will be one below other block-level elements (default).There are three serive divs in the red area will follow the ** flex justify-center items-stretch** rule.
data:image/s3,"s3://crabby-images/b5258/b525845afc4686fd3cc734022739e1eb43f74dc1" alt=""
data:image/s3,"s3://crabby-images/cab8a/cab8aae71026e02329470b246ec5324e2f0f21d5" alt=""
Each Red Block will be one below other block-level elements. There children elements in the red block are flex (blue area), the orange block will be one below other block-level elements.
data:image/s3,"s3://crabby-images/731b0/731b096aa684044c6d4c7e09305d6082251c6a64" alt=""
The following two ways of writing can achieve this effect
<div class="w-full h-screen flex flex-col justify-center"> | <div class=”w-full h-screen flex”> <div class=”item m-auto“> I’m at the center of this page </div> </div> |
data:image/s3,"s3://crabby-images/5d3de/5d3de5488cccf24939947ad695fc8f66859b17b8" alt=""
The justify-* control spacing and aligment along the main axis, while the item-* control alignment along the cross axis. So that this example we use flex-col justify-center.
data:image/s3,"s3://crabby-images/92e4a/92e4a1f6a24ab11e9a25c2c884deae494771df35" alt=""
<div class="card flex flex-col justify-between items-start">
<img src="https://res.cloudinary.com/thirus/image/upload/v1629308145/logos/quote-left_tsopjj_zviayy.svg" alt="">
<p>
I just finished my trial period and was so amazed with the support and good results that I purchased the Pro version for my business.
</p>
<span>John Doe</span>
</div>
data:image/s3,"s3://crabby-images/77a65/77a6503a6d4b5e704870e77dec50b385d8b51f6f" alt=""
<div class="wrapper"> | <div class="wrapper"> |
data:image/s3,"s3://crabby-images/19d84/19d844f4cf7ac6d02556822126911f93212e2158" alt=""
<div class="wrapper">
<div class="container flex">
<input type="email" class="flex-grow" placeholder="Email Address">
<button type="submit">Subscribe</button>
</div>
</div>
The second picture: +flex, the third picture: +flex-grow, the flow-grow will make the item grows to occupy remaining space alog the main axis.
data:image/s3,"s3://crabby-images/5628b/5628b95dc0ed1c9b6140b523e3f79406a1813fa8" alt=""
If your element needs to fill the entire screen independently, use min-h-screen.
<div class="container flex min-h-screen flex-col">
<div class="main flex-grow">
<h1>Main Content</h1>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Ex perferendis repellat, cum ratione fugit dolorum sequi dolores odit commodi cupiditate ab excepturi deserunt laborum saepe, praesentium id deleniti aperiam eaque.</p>
<p>Sed egestas, ante et vulputate volutpat, eros pede semper est, vitae luctus metus libero eu augue. Morbi purus libero, faucibus adipiscing, commodo quis, gravida id, est. Sed lectus. Praesent elementum hendrerit tortor. Sed semper lorem at felis. Vestibulum volutpat, lacus a ultrices sagittis, mi neque euismod dui, eu pulvinar nunc sapien ornare nisl. Phasellus pede arcu, dapibus eu, fermentum et, dapibus sed, urna.</p>
</div>
<footer>
<h3>Footer</h3>
</footer>
</div>
data:image/s3,"s3://crabby-images/58996/5899665c279b2ee5b324c32f32ea55c40691c5eb" alt=""
@tailwind base;
@tailwind components;
@tailwind utilities;
@layer base {
body {
@apply bg-gray-200 text-gray-700;
}
}
@layer components {
p {
@apply text-center my-8;
}
ul {
@apply bg-white my-8 mx-auto;
width: 44rem;
}
ul li {
@apply p-5 text-center cursor-pointer
transition-all duration-200 border-b-2 border-white
hover:border-green-400
}
}
<p>Hover over the links below 👇</p>
<ul class="flex">
<li class="flex-grow">Description</li>
<li class="flex-grow">Care Instructions</li>
<li class="flex-grow">Return Policy</li>
</ul>
data:image/s3,"s3://crabby-images/88782/887824489d12fe2c2d4c5f9180ac2b502970f018" alt=""
This Tailwind CSS code makes the elements inside the flex-grow and triple in size on hover.
<p>Hover over the links below 👇</p>
<ul class="flex">
<li class="flex-grow hover:flex-grow-[3]">Description</li>
<li class="flex-grow hover:flex-grow-[3]">Care Instructions</li>
<li class="flex-grow hover:flex-grow-[3]">Return Policy</li>
</ul>
data:image/s3,"s3://crabby-images/d44e2/d44e257d7f964e5251a50311e1fc1a00d77983a7" alt=""
@tailwind base; | <div class="container flex flex-wrap"> |
data:image/s3,"s3://crabby-images/d93a6/d93a6ef4587741c565a8d6701061384f5d54bc83" alt=""
<div class="container flex items-start">
<div>
<h2>Visit to the Eiffel Tower</h2>
<p>There's no better start to your Paris tour than visiting the iconic Eiffel Tower. This is a must visit tourist spot in the whole of France.</p>
</div>
<span class="flex-shrink-0">10:00 AM</span>
</div>
<div class="container flex items-start">
<div>
<h2>Lunch at New Jawad</h2>
<p>It is an Indian restaurant close to the Eiffel Tower. Enjoy delicious Indian traditional food and South Asian food.</p>
</div>
<span>1:00 PM</span>
</div>
In the first .container (the Visit to the Eiffel Tower block):
The span has flex-shrink-0 so it won’t shrink, even if there’s not enough space it will still stay the same size.
In the second .container (the Lunch at New Jawad block):
The span doesn’t have flex-shrink-0, so when there’s not enough space, it may shrink to fit the available space.
data:image/s3,"s3://crabby-images/3c572/3c57204ef82afde38c80cb1ada61a5887f05f344" alt=""
data:image/s3,"s3://crabby-images/0768e/0768e45d5706fdee1cbd2bc9852edbc36fe7a29b" alt=""
<div class="profile flex items-center">
<img src="https://images.pexels.com/photos/220453/pexels-photo-220453.jpeg?auto=compress&cs=tinysrgb&dpr=2&w=80" alt="" class="flex-shrink-0 profile-img" />
<div>
<h3>Matt Cooper</h3>
<p>A front end web developer from New York, USA. Currently working as a freelancer. Drop a mail or say hello 👋</p>
</div>
</div>
data:image/s3,"s3://crabby-images/7628b/7628b8e853397cbe77152daa7365d24f0ec84bf3" alt=""
data:image/s3,"s3://crabby-images/9cc79/9cc799d7f424fe7b8613b64d8b720f7d2435c2fe" alt=""
<div class="container w-full h-screen flex flex-col md:flex-row">
<div id="learn" class="split h-1/2 md:w-1/2 md:h-full">
<div>
<h1>Learn</h1>
<p>Build your skillset with the hottest courses</p>
<a href="#">Start Learning</a>
</div>
</div>
<div id="teach" class="split">
<div>
<h1>Teach</h1>
<p>Share your knowledge and earn some income</p>
<a href="#">Start Teaching</a>
</div>
</div>
</div>
This code creates a full-screen-height double-column (or double-row) block that is displayed top-to-bottom on small screens and left-to-right on large screens, depending on the screen size.
data:image/s3,"s3://crabby-images/6b6c2/6b6c2b7cc65236e70bfd4e59e07f57450f97a905" alt=""
data:image/s3,"s3://crabby-images/161f0/161f0f742b7a4df65db5bd066529f1a52260086c" alt=""
data:image/s3,"s3://crabby-images/d5e7e/d5e7ea39d381ea83349948ba391ad5862c2fc36b" alt=""
data:image/s3,"s3://crabby-images/1b16b/1b16b3d1eb767990071ea8b0fe660b5d86560f8d" alt=""
mx-4 control the horizontal margin of an element, basis-1/3 set the initial size of flex items to be 1/3 parent width.
<div class="wrapper">
<div class="container flex">
<div class="plan mx-4 basis-1/3">
<h2>Standard</h2>
<span>Monthly Plan</span>
<p>$25</p>
</div>
<div class="plan plan-highlight mx-4 basis-1/3">
<h2>Popular</h2>
<span>Monthly Plan</span>
<p>$40</p>
</div>
<div class="plan mx-4 basis-1/3">
<h2>Premium</h2>
<span>Monthly Plan</span>
<p>$55</p>
</div>
</div>
</div>
basis-0 flex-grow: Let the element share the remaining space equally;
<div class="wrapper">
<div class="container flex">
<div class="plan mx-4 basis-0 flex-grow flex-shrink">
<h2>Standard</h2>
<span>Monthly Plan</span>
<p>$25</p>
</div>
<div class="plan plan-highlight mx-4 basis-0 flex-grow flex-shrink">
<h2>Popular</h2>
<span>Monthly Plan</span>
<p>$40</p>
</div>
<div class="plan mx-4 basis-0 flex-grow flex-shrink">
<h2>Premium</h2>
<span>Monthly Plan</span>
<p>$55</p>
</div>
</div>
</div>
we can use the flex-* shorthand utility. to replace all those three css classes with a single class.
<div class="wrapper">
<div class="container flex">
<div class="plan mx-4 flex-1">
<h2>Standard</h2>
<span>Monthly Plan</span>
<p>$25</p>
</div>
<div class="plan plan-highlight mx-4 flex-1">
<h2>Popular</h2>
<span>Monthly Plan</span>
<p>$40</p>
</div>
<div class="plan mx-4 flex-1">
<h2>Premium</h2>
<span>Monthly Plan</span>
<p>$55</p>
</div>
</div>
</div>
Tailwind Class | CSS Property & Value | Explanation |
flex-1 | flex: 1 1 0%; | Flex item grows and shrinks as needed ignoring the initial size. If this is used on multiple items, all the items take up equal space. |
flex-auto | flex: 1 1 auto; | Flex item grows and shrinks as needed considering the initial size . If this is used on multiple items, all the items take up space based on their content. |
flex-initial | flex: 0 1 auto; | This is the default. The item shrinks when space is less but does not grow when there’s space available. Initial size is auto-calculated. |
flex-none | flex: none; | The item does not grow, nor shrink. |
Synax flex: <flex-grow> <flex-shrink> <flex-basis>, the values must be in the following order: 1. a <number>for flex-grow 2. a <number> for flex-shrink 3. a <number with units> for flex-basis fex: 1 1 0%; flow-grow + flow-shrink + basis-0 flex: 1 1 auto; flow-grow + flow-shrink + basis-auto flex: 0 1 auto; flow-grow-0 + flow-shrink + basis-auto flex none: flow-grow-0 + flow-shrink-0 + basis-auto |
data:image/s3,"s3://crabby-images/262cc/262cc452641fd357b771465c5b0baf088d32270b" alt=""
data:image/s3,"s3://crabby-images/e1d11/e1d116101f19473569a8505d58fcb753da89f875" alt=""
<footer class="flex">
<div class="footer-col">
<img src="https://res.cloudinary.com/thirus/image/upload/v1628614672/logos/circleai_dm9slt.png" alt="Circle AI Logo" height="30" />
<p>The Company Tagline</p>
</div>
<div class="footer-col ml-auto">
<h3>Quick Links</h3>
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
<div class="footer-col">
<h3>Contact Us</h3>
<ul>
<li></li>
<li></li>
</ul>
</div>
<div class="footer-col">
<h3>Social</h3>
<ul>
<li></li>
<li></li>
<li></li>
</ul>
</div>
</footer>
data:image/s3,"s3://crabby-images/92831/9283136afc6f63cab9591fb67b81d3c30a40d183" alt=""
data:image/s3,"s3://crabby-images/98298/9829865680d834c75aa2a82ddbbbfc62b34a9b4d" alt=""
<header class="flex flex-wrap justify-between items-center">
<a href="#" class="flex-1">
<img class="inline h-7" src="https://res.cloudinary.com/thirus/image/upload/v1628614672/logos/circleai_dm9slt.png" alt="" />
</a>
<ul class="order-last flex-[100%] mt-4 md:order-none md:flex-auto md:mt-0">
<li>
<a href="#">Home</a>
</li>
<li>
<a href="#">About Us</a>
</li>
<li>
<a href="#">Pricing</a>
</li>
</ul>
<span class="flex-1 text-right">
<a href="#" class="btn">Join us</a>
</span>
</header>
- small screen
- order-last //ul will be placed at the end of the header, so the logo and “Join us” appear first, and the navigation menu is at the end.
- flex-[100%] //flex-[100%] makes ul occupy the entire line (block level display)
- mt-4
- large screen
- order-none
- flex-auto // Let ul adjust its width according to the content size in flex layout
- mt-0
data:image/s3,"s3://crabby-images/e8508/e85087ee4e129cb76de4f7d5db428f003ce5888a" alt=""
<div class="container flex flex-col">
<img src="https://images.pexels.com/photos/1464625/pexels-photo-1464625.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=300" alt="" />
<span>$220</span>
<h3>Comfort Grey Sneakers</h3>
<p>Lorem ipsum dolor sit, amet consectetur adipisicing elit. Dicta cum impedit veniam</p>
<button class="self-end">Add to Cart</button>
</div>
Align-self utilities for controlling how an individual flex or grid item is positioned along its container’s cross axis. Because we use flex-col so the main axis is upside-down, cross axis is left-to-right. so the self-end will make the button align right.
data:image/s3,"s3://crabby-images/1ba32/1ba32c027209a5bd028cd82329fe390d097416fa" alt=""
<div class="container flex items-center">
<img src="https://images.pexels.com/photos/7562313/pexels-photo-7562313.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=100" alt="">
<div>
<p>Richard Carl</p>
<span>Graphic Designer</span>
</div>
<div class="rating ml-auto self-start">
<i class="fa fa-star"></i>
<span>5.0</span>
</div>
</div>
data:image/s3,"s3://crabby-images/b2c2f/b2c2f7828dc146b5ca6eb17c8fa84c0e7c0e6a5a" alt=""
data:image/s3,"s3://crabby-images/4279f/4279fd9eba4d715783acb9796044e518ca46571c" alt=""
<div class="container flex flex-wrap justify-center content-center">
<h1 class="flex-full text-center">What people are saying about my eBook</h1>
<div class="testimonial">
<p>"Just ordered my copy! Shruti is awesome and I suck at grid.<br />No brainer."</p>
<span><strong>- Caleb Porzio</strong></span>
</div>
<div class="testimonial">
<p>"It's the best e-book experience I've had on this subject. Might even understand this Flex/Grid stuff myself after all."</p>
<span><strong>- Lucian Tartea</strong></span>
</div>
<div class="testimonial">
<p>"I think there is a 0 missing at the end of these prices. $8 for this much awesomeness? It should be 800!"</p>
<span><strong>- Jimi Wikman</strong></span>
</div>
<div class="testimonial">
<p>"I love that you have used real world examples to describe the concepts which is very helpful to understand."</p>
<span><strong>- Sumudu Siriwardana</strong></span>
</div>
<div class="testimonial">
<p>"My CSS Grid abilities aren’t quite where I want them to be so I’m excited to dive into the full release"</p>
<span><strong>- Jacob Foster</strong></span>
</div>
</div>
data:image/s3,"s3://crabby-images/fcfbd/fcfbd1c209513423691ef67499e30f1d5c444374" alt=""
data:image/s3,"s3://crabby-images/81cf7/81cf701893fc196981148b5fd6d33700116112c7" alt=""
data:image/s3,"s3://crabby-images/5bc78/5bc78a0263d1d56d37e922d481c7e62f2427ae14" alt=""
data:image/s3,"s3://crabby-images/9ef20/9ef203c5b660f7ab1099097ce581743ad31d76c3" alt=""
data:image/s3,"s3://crabby-images/56694/5669473259da34e8e316bbbc025f40b0aa55ae05" alt=""
data:image/s3,"s3://crabby-images/16195/1619576c94dd31ec39157aa5ec579902fd2d56f0" alt=""
data:image/s3,"s3://crabby-images/6085c/6085c9085695052716cc5c6cb879f815752867a9" alt=""
<a class="icon inline-flex justify-center items-center" href="#">
<i class="fa fa-twitter"></i>
</a>
<a class="icon inline-flex justify-center items-center" href="#">
<i class="fa fa-linkedin"></i>
</a>
<a class="icon inline-flex justify-center items-center" href="#">
<i class="fa fa-github"></i>
</a>
But the utility inline-flex does not affect the flex items.
It makes the flex container itself behave like an inline element instead of a block
element
data:image/s3,"s3://crabby-images/0a9bc/0a9bc274da8c1a6754cbe668c29f11226781e174" alt=""
<div class="wrapper">
<div class="container flex flex-col md:flex-row">
<div class="flex-[40%]">
<img class="article-img" src="https://res.cloudinary.com/thirus/image/upload/v1632854291/logos/drawers_gr2wn5.jpg" alt="Furniture" />
</div>
<div class="details flex-[60%]">
<h2>Shift the overall look and feel by adding these wonderful touches to furniture in your home</h2>
<p>Ever been in a room and felt like something was missing? Perhaps it felt slightly bare and uninviting. I've got some simple tips to help you make any room feel complete.</p>
<div class="article-footer flex items-center">
<img src="https://res.cloudinary.com/thirus/image/upload/v1632854290/logos/avatar-michelle_qcobnu.jpg" alt="" />
<div>
<p>Michelle Appleton</p>
<span>28 Jun 2020</span>
</div>
<div class="share-icon ml-auto">
<img src="https://res.cloudinary.com/thirus/image/upload/v1632854290/logos/icon-share_frvrfu.svg" alt="" />
</div>
</div>
</div>
</div>
</div>
data:image/s3,"s3://crabby-images/1c921/1c921c20e232d8835e09e9d379f131bf1060eab3" alt=""
<h1>Daily Average Stats</h1>
<div class="container flex flex-wrap">
<div class="report flex-1 flex flex-col min-w-[12rem] justify-between">
<span>Avg. Steps /day</span>
<span>9,340</span>
<div>
<p><strong>+355</strong></p>
<span>last month</span>
</div>
</div>
<div class="report flex-1 flex flex-col min-w-[12rem] justify-between">
<span>Minutes /day</span>
<span>94</span>
<div>
<p><strong>+12</strong></p>
<span>last month</span>
</div>
</div>
<div class="report flex-1 flex flex-col min-w-[12rem] justify-between">
<span>kCal Burnt /day</span>
<span>142</span>
<div>
<p><strong>+22</strong></p>
<span>last month</span>
</div>
</div>
</div>