Tailwind CSS explained

Tailwind CSS
Author:Adam Wathan, Jonathan Reinink, David Hemphill, and Steve Schoger
Developer:Tailwind Labs[1]
Released:[2]
Programming Language:TypeScript, Rust, CSS
Platform:Web
Language:English
License:MIT License[3]

Tailwind CSS is an open-source CSS framework. Unlike other frameworks, like Bootstrap, it does not provide a series of predefined classes for elements such as buttons or tables. Instead, it creates a list of "utility" CSS classes that can be used to style each element by mixing and matching.[4] [5]

For example, in other traditional systems, there would be a class that would apply a yellow background color and bold text. To achieve this result in Tailwind, one would have to apply a set of classes created by the library: and .

As of 5 August 2024, Tailwind CSS has over 81,000 stars on GitHub.

Features

Due to the difference in basic concepts in relation to other traditional CSS frameworks such as Bootstrap, it is important to know the philosophy from which Tailwind was created, as well as its basic usage.

Utility classes

The utility-first concept refers to the main differentiating feature of Tailwind.[6] Instead of creating classes around components (button, panel, menu, textbox ...), classes are built around a specific style element (yellow color, bold font, very large text, center element...). Each of these classes is called utility classes.

There are many utility classes in Tailwind CSS that enable to control a large number of CSS properties like colors, border, display type (display), font size and font, layout, shadow...

Result
Code

Please be careful when feeding the birds.

ClassesTailwindCSS equivalent
margin: 1rem;
padding: 1rem;
background-color: rgb(254 240 138);
font-weight: 700;
border-radius: 0.5rem;

Variants

Tailwind offers the possibility to apply a utility class only in some situations through media queries, which is called a variant. The main use of variants is to design a responsive interface for various screen sizes.[7] There are also variants for the different states an element can have, such as for when hovered, when keyboard selected or when in use,[8] or when the browser or operating system has dark mode enabled.[9]

Variants have two parts: the condition to be met and the class that is applied if the condition is met. For example, the variant will apply the class if the screen size is at least the value defined for .

Tailwind CSS is developed using JavaScript, runs via Node.js, and installs with environment package managers like npm or yarn.[10]

Settings and themes

It is possible to configure the utility classes and variants that Tailwind offers through a configuration file usually named . In the configuration, one can set the values of the utility classes, such as the color-palette or the sizes between elements for margins.

Build all and purge

The default mode of Tailwind is that the system generates all possible CSS combinations based on the project settings. Then, by means of another utility such as PurgeCSS, all the files are traversed, and the classes that are not being used are removed from the resulting CSS file.

Due to the number of classes that can be generated by the number of variants and their combinations, this method has the drawbacks of long waiting times and large sizes of CSS files before being purged. This mode of operation is no longer available in version 3 of Tailwind CSS.[11]

Just-in-time mode

JIT mode (Just-In-Time) is an alternative way to generate the CSS that, instead of generating all possible classes and then removing all those that are not being used, parses the content of HTML files (or configured extensions or locations) and instantly generates only those classes that are needed and used.

By generating only the necessary CSS, JIT significantly reduces the size of the CSS file. This technical improvement has made it possible to introduce numerous new variants and utility classes, as well as the ability to create utility classes on the fly with arbitrary values not set in the configuration.

Starting with version 3 of Tailwind CSS, JIT mode has become the default.

Versions

Tailwind CSS uses semantic versioning to identify its version compatibility.

See also

External links

Notes and References

  1. Web site: Tailwind Labs. .
  2. Web site: Release Notes: Tailwind CSS v1.0 . Doe . Tailwind CSS . 2024-08-17.
  3. Web site: Github: tailwindlabs/tailwindcss, LICENSE. .
  4. Book: Gerchev, Ivaylo . Tailwind CSS . 2022 . O'Reilly Media . 978-1-0981-4099-1 . Sebastopol . 1314257318.
  5. Book: Rappin, Noel . Modern CSS with Tailwind flexible styling without the fuss . 2021 . 978-1-68050-857-4 . The Pragmatic Bookshelf. Raleigh . 1277046918.
  6. Web site: Utility-First - Tailwind CSS. 2021-11-13. tailwindcss.com. en.
  7. Web site: Responsive Design - Tailwind CSS. 2021-11-13. tailwindcss.com. en.
  8. Web site: Hover, Focus, & Other States - Tailwind CSS. 2021-11-13. tailwindcss.com. en.
  9. Web site: Dark Mode - Tailwind CSS. 2021-11-13. tailwindcss.com. en.
  10. Web site: Installation - Tailwind CSS. 2021-11-13. tailwindcss.com. en.
  11. Web site: Release v3.0.0-alpha.1 tailwindlabs/tailwindcss. 2021-11-13. GitHub. en.