A short summary:

Found problems: CSS code pain points in the project

.mock {    
    margin: auto;    
    font-size: 16px;    
    // ...
}
<div class='mock'>mock</div>
Copy the code

The above code is an example. In most cases, you would write a class and put a bunch of styles in it. When you write this way too much, you will feel some pain points, such as:

1) It is difficult to name, with many node structures, it is really difficult to name. Of course, some naming problems can be circumvented by using specifications or selectors.

  1. When you need to use JS to control the style, you have to write another class, especially for interactive scenarios.

  2. Component reuse is well understood, but style reuse is rare, resulting in more redundant code.

  3. Global pollution, which is actually now a lot of tools can help us solve automatically.

  4. Dead code issues. JS We’re tree shaking code away to reduce file size, but what about CSS? Especially as projects get bigger, useless CSS code always appears.

  5. The insertion order of the stylesheet affects how the CSS actually works.

Introduction to Tailwind CSS

Tailwind can quickly add styles to HTML elements and provides a wide range of out-of-the-box design styles.

Tailwindcss is a CSS framework based on the idea of tool classes that are smaller and more flexible than components. The idea is simply to use classes to ensure flexibility and ease of customizing components, rather than personalization on top of them.

Website: www.tailwindcss.cn/

If you’ve never seen Tailwind in action, check this out:

<div class="bg-gray-100 rounded-xl p-8">Hello World</div>
Copy the code

The class name here reflects the definition of Tailwind: a collection of predefined classes (called utility classes). You don’t need to write basic CSS style rules, just apply predefined class names directly to HTML.

There are many more such class names. The following list shows some of the categories and their examples:

1) Background (BG-Gray-200, BG-gradient-to-BL)

2) Flexible layout (Flex-1, Flex-row)

3) Grid layout (Grid-COLs-1, COL-SPAN-4)

4) Inside margin (P-0, P-1)

5) Size (W-1, H-1)

When developing large applications, each HTML element is flooded with Tailwind utility class names.

<div class="sm:w-4 md:w-6 lg:w-10 xl:w-full sm:text-sm md:text-base lg:text-base xl:text-2xl flex-1 sm:flex-none bg-black sm:bg-white rounded-md sm:rounded-none"> 
  hello world
</div>
Copy the code

Question:

How do you organize these class names? Maybe we want to create and follow some sort of rule.

Solution:

Some HTML elements use a lot of styles, and in such cases you should consider separating the styles from the HTML tags and putting them in a separate file. This way, we can organize the style and make it more readable. You can’t cram all CSS functionality into the class HTML tag property, and neither can Tailwind. Doing so only makes the HTML structure more bloated.

@apply

Tailwind allows us to use their class names in a single CSS file for the problems mentioned above:

.header { @apply bg-red-200 w-4 text-gray-400 rounded-sm border-2; }Copy the code

For example, buttons in a project have common rounded corners, margins, fonts, etc., so we can encapsulate a class like this:

.btn { @apply p-8 rounded-xl font-semibold; }Copy the code

Reasons to use Tailwind CSS

1. Ultra-small file size = incredible performance

In development mode, Tailwind’s output size is very large. This is by design: every possible class is generated at this stage, so you don’t have to wait for the build process to complete when you want to use something.

However, once Tailwind CSS is in production mode, all classes that are not used with PurgeCSS tools are removed. This is done by searching the project file for the name of the class, keeping only those that have been used. You can configure which file paths to search for in the Purge array tailwind.config.js.

// tailwind.config.jsmodule.exports = {  purge: [    "./src/**/*.html",    "./src/**/*.vue",    './src/**/*.js'  ],  theme: {},  variants: {},  plugins: [],}
Copy the code

2. Prototyping and rapid building

With regular SCSS, you write custom classes for each element on the page. This provides better control, but writing custom classes takes a lot of time: you have to add classes in HTML, create them in CSS, and write out each property in long format. You have to wait for your CSS to build to see the results — and, if you need to make more changes, you have to rebuild every time, which can take a few seconds and disrupt your process.

Tailwind CSS eliminates these extra steps and provides a simple, crisp development experience when styling elements. You can see that the element you want to style, using shorthand to add the desired attributes, can change quickly without waiting for the CSS bundle. So just focus in one place and don’t have to constantly switch to different files, and the process feels smooth.

<div class="bg-white rounded p-4"> <h1 class="text-24 font-heading underline"> Foobar </h1> <p class="text-16 font-body>  Hello world! </p></div>Copy the code

3, eliminate the scope of leakage

The reason people love BEM and why it is so popular today is that naming system classes are built to represent the structure of components. While making it easy to read and understand, developers also benefit from this structure: because the layout is easy to understand, classes can be written without using CSS selectors. As follows:

// this.block { &__element { ... } &__element--modifier { ... }}// not this.block { & > .element { &.modifier { ... }}}Copy the code

The problem with CSS selectors is that they introduce complexity into CSS: components become very dependent on a particular HTML structure. Because generic CSS classes, such as.container, can be repeated many times, using these names can lead to overlap, so changing one class will affect many others. This is one of the main reasons we use BEM, because it makes the structure clear and flattens each class to the top range so it doesn’t depend on each other. Without a CSS approach like this, development can be a pain in the neck, and its simplicity means it’s easier for others to understand.

Why Tailwindcss is so popular

Tailwind tags in npm. DEVTOOL

Address: NPM. Devtool. Tech/tailwindcss

Now the TailwindCSS used in the project development, here to talk about a little bit of feeling, TailwindCSS because a class represents a CSS property this kind of Atomic CSS, this kind of fine grained CSS scheme is controversial.

1. Four particle sizes

<div style=" borderRadius: '0.5rem', padding: '1rem' }"> Click </div><div class="rounded-lg p-4"> Click </div><div class="button"> Click </div><Button> Click </Button>Copy the code

However, flexibility is always inversely proportional to development workload. The higher the flexibility is, the more work the developer needs to deal with by himself. Therefore, how to balance the relationship between development workload and flexibility becomes particularly important.

Because it involves the choice of CSS library, BootStrap library is more to provide the form of granularity 3, given a fixed style, developers need to customize the style to rewrite the style, while Tailwind is to provide the form of granularity 2 atomic style, more to provide a specification. It then gives developers more freedom to assemble the styles.

2. Answers to some questions

Tailwindcss is popular for nothing more than atomized CSS that is easier to use. It is in full swing in foreign countries, but it is very controversial in domestic forums. A few days ago, I wrote an article about Tailwindcss on the front-end big guy blog, but there are many kinds of problems under the comments, so let’s sum up

Q1: What’s the difference between tailwind and inline CSS?

Most people think this: Text-center alone is a little convenient, but not enough to make a difference.

If it’s just simple atomized CSS, it’s easy to use but not brilliant. But it doesn’t stop there.

1. Convenience: Text-center, grid-COLs-3

Maybe a text-center isn’t enough to give you the benefit of the doubt, but a grid-Cols-3 and shadow is definitely handy for a triscale Grid property.

.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }Copy the code

2. Semantic: text-lg, text-white, ring, animal-spin ‘

Text-lg, a large font, has a lot of trouble with inline styles: I want to design a large font, what size should I design it, and what units should I use?

Also:

Text-white: What is the color value of white?

Ring: I want to put a circle around this button?

Animate: How do YOU make an animation?

3. Response:

Let’s take a look at one of the most responsive layout problems I’ve ever encountered in my last headline interview

Responsive layout, a bunch of sub-elements, tripartite on the big screen, tripartite on the medium screen, tripartite on the small screen?

<div class="container">  <div class="item"></div>  <div class="item"></div>  <div class="item"></div>  <div class="item"></div>  <div class="item"></div>  <div class="item"></div></div>
Copy the code

Grid layout is easy to implement, but cumbersome

@media (min-width: 1024px) {. Container {grid-template-columns: repeat(3,minmax(0,1fr)); }}@media (min-width: 768px) {. Container {grid-template-columns: repeat(2,minmax(0,1fr)); }}.conainer { display: grid; gap: 1rem; }Copy the code

What about using tailwind? Just one line, ask you if you’re efficient.

<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4"></div>
Copy the code

4. The modifier

The prefixes of modifiers such as pseudo-classes, dark patterns, and reactive design are very much in my heart.

<div class="focus:ring-2 hover:bg-red-700 dark:bg-gray-800"></div>
Copy the code

Q2: since TailwindCSS is so good, you can get rid of handwritten CSS

Unfortunately, I can’t. But while you can’t get rid of handwritten CSS, you can’t write more than a few lines. Here are some common cases.

1. Complex selector

Style control for child elements while the parent element is hovering

.container:hover .item {}
Copy the code

2. CSS function

.body {  height: calc(100vh - 6rem)}
Copy the code

3. Multiple attributes reuse

.item { @apply p-2 border-b flex justify-between font-mono; }Copy the code

Q3: Creating a new memory burden

The template syntax of Vue is often used in this way. Many people will naturally reject some naming conventions, especially those they don’t like.

In the early days, it was true that while developing a web page, I looked at the document global search: TailwindCSS property search. Now with the help of browser plugins and practice makes perfect, I don’t need to dig through the document as much.

1. Tailwind CSS IntelliSense (vscode)

Intelligent completion

Code hinting

In the early days, I often spent time flipping through documents rather than writing CSS by hand for two reasons:

1, write a few more letters, really a little too much trouble, have this time is better to look at the document, global search is not trouble;

2, set your own fontSize, padding, margin really do not know how to set the size, tailwindCSS has a large constraint;

How long does it take to be like, HMM, that smells good.

Tailwindcss project practice

The traditional way to write this is to define a class and write the desired style:

.class1 { font-size: 18px; margin: 10px; }.class2 { font-size: 16px; color: red; margin: 10px; }Copy the code

There is some duplication in this style, so switching to Atom CSS reduces some of the redundancy in the code.

Write CSS as a component. At first glance the tailwindcss website will definitely feel that I have to type so many classes to write a style in HTML is not good.

<figure class="md:flex bg-gray-100 rounded-xl p-8 md:p-0"> <img class="w-32 h-32 md:w-48 md:h-auto md:rounded-none rounded-full mx-auto" src="/sarah-dayan.jpg" alt="" width="384" height="512"> <div class="pt-6 md:p-8 text-center Md :text-left space-y-4"> <blockquote> <p class="text-lg font semibold"> "Tailwind CSS is the only framework that I've Seen scale on large teams. It's easy to customize, ADAPTS to any design, </p> </blockquote> <figcaption class=" text-medium "> <div class="text-cyan-600"> Sarah Dayan  </div> <div class="text-gray-500"> Staff Engineer, Algolia </div> </figcaption> </div></figure>Copy the code

Instead, we can take advantage of the one-at-a-time nature of Atom CSS to assemble these classes into whatever we want, providing a higher level of generic styles that can be reused.

Tailwind.confing.js configuration file

/ * * * * custom configuration default configuration. Please refer to https://unpkg.com/browse/[email protected]/stubs/defaultConfig.stub.js * / module exports = {purge: [ "./src/**/*.html", "./src/**/*.vue", './src/**/*.jsx' ], theme: { extend: { fontFamily: { sans: [" system ", "Roboto", '" Segoe UI "], dincond: [" dincond - Black "]}, fontSize: {' 2.5' : '0.625 rem, / / 10 px' 3 ': '0.375 rem', / / 12 px '5.5 xl' : '3.25 rem', / / 52 px '4.5 xl' : '2.5 rem', / / 40 px}, width: {' 4.5 ':' 1.125 rem, / / 18 px '10.5' : '2.65 rem, / / 42 px' 15 ':' 3.75 rem ', / / 60 px '18' : '4.5 rem', / / 74 px '18.5' : '4.625 rem', / / 74 px '23' : '5.75 rem / / 92 px}, lineHeight: {' 12' : '3 rem, / / 48 pixels' 15' : '3.875 rem', / / 62 px '16', '4 rem', / / 64 px '14' : '3.5 rem, / / 56 px "18" : "4.625 rem / / 74 px"}, padding: {' 0.5' : '0.125 rem, / / 2 px' 5.5 ':' 1.375 rem ', / / 22 px '4.5' : '1.125 rem', / / 18 px '0.75' : '0.1875 rem', / / 3 px '7.5' : '1.875 rem / / 30 px}, paddingBottom: {' 4.5' : '1.375 rem / / 22 px}, margin: {' 4.5' : '1.125 rem, / / 18 px' 15 ':' 3.75 rem ', / / 60 px '21.25' : '5.3125 rem', / / 85 px '11.5' : '2.875 rem, / / 46 px' 19 ':' 4.75 rem ', / / 76 px}, marginTop: {' 6.5 ':' 1.625 rem, / / 26 px}, spacing: {' 3.5 ': '0.875 rem, / / 14 px' 7.5 ':' 1.875 rem ', / / 30 px '9.5' : '2.375 rem, 38 px / / / /' 15 ':' 3.375 rem ', / / px '11.5' 54: '2.875 rem, / / 46 px' 23 ':' 5.75 rem ', / / 92 px '28' : '7 rem, / / 112 px' 98 ', '39 rem', / / 624 px}, height: {' 0.25 ': '0.0625 rem', / / 1 px '0.75' : '0.1875 rem', / / 3 px '14' : '3.5 rem', / / 56 px '10.5' : '2.65 rem / / 42 px}, backgroundColor: {' primary - a100 ':' rgba (43, 121, 255, 0.1) ',}, borderRadius: {' 5.5 ':' 1.375 rem '}, / / 22 px zIndex: {' 6 ': 6 / / z - index:}, screens: {' 3 xl ':' 1664 px ', '4 xl' : '1792 px'}, scale: {' 85 ', '85', / / 0.85 rem}}}, plugins: [ require("tailwindcss-theming")({ variants: { light: true } }) ]};Copy the code

Now that we know what Tailwind CSS is? How to use Tailwind CSS? Tailwind CSS and the use of plugins, we believe that you have a comprehensive understanding of Tailwind CSS.