3 underused CSS features to learn for 2020

Bryan Robinson - Dec 18 '19 - - Dev Community

CSS has a whole lot of power. There are properties and values for any number of amazing designs. With all that power comes a lot to remember.

If you don't know about all the tools in your toolbox, how will you find the right one for the job?

In this post, we'll take a look at three lesser-used, but super useful tools for various jobs in CSS.

1. How to have readable line-lengths with the ch unit

There is a plethora of amazing length units in CSS, so why let px and rems have all the fun?

We've known for a long time that line length has a lot to do with how easily a person can read content. We've had more issues determining the proper size with static lengths like pixels. Enter the ch length unit in CSS.

The definition of the ch unit is the width of the 0 character in the current font size. While not perfect, this allows us to specify a width for a column of content to be equal to an "ideal" number of characters. In the Smashing Magazine article linked above, the author indicates a comfortable line length to be between 45 and 85 characters wide. Instead of doing calculations and figuring out the proper amount of pixels, we can substitute the "character unit" to keep things balanced.

.centered-column {
    width: 90vw;
    max-width: 75ch;
    margin-left: auto;
    margin-right: auto;
}
Enter fullscreen mode Exit fullscreen mode

With this snippet, you now have a centered column that will never exceed a maximum recommendation.

If you adjust the font size at various breakpoints, the max-width of the column will expand or contract. If you decide to change fonts, the max-width will adjust.

The one caveat I'll throw in here is that you don't want to use this for precise measurements. This should always be approximations. Since the ch unit keys off of the 0 glyph in the font, greater or fewer characters may be on each line. Take this relatively simple example.

Image showing four 0s side by side and a group of Ms where only 2 Ms fit next to each other

In the image above, only two M characters fit side by side in the same space as four 0 characters. That's because each capital M is roughly 36 pixels wide; each 0 is 20 pixels. Combine this with each font having different glyphs and you get something not precise. Since our code example doesn't worry about precision and just wants the line length around 75 characters wide, we're safe.

2. How to simplify your CSS with CSS Attribute selectors

I'm not overly surprised that ch units don't have much popularity. They feel very tied in with design concerns. Attribute selectors, however, shock me in their lack of use. They're so versatile and feel very programatic.

At their core, Attribute selectors allow you to select an HTML element that has a specific attribute or has a certain value of an attribute.

One of my favorite new uses of the attribute selector comes from Andy Bell's amazing new CSS reset.

In his reset -- which is full of well-thought-out configurations -- he uses attribute selectors to remove margins and paddings only from uls and ols that have classes. The thinking being that if you set a class on the item, you probably are resetting the list's styles. If you don't have a class, you probably want a bulleted or numbered list.

ul[class],  
ol[class] {  
    padding: 0;  
    margin: 0;
}
Enter fullscreen mode Exit fullscreen mode

You could also apply this to anchor tags that have a target attribute. Use this in conjunction with an ::after element to add a small icon for links that will take a user into a popup window.

a[target] {
    padding-right: 2ch;
}

a[target]::after {
    background-image: url(icon.svg);
    width: 1.75ch;
    height: 1em;
    ...etc.
}
Enter fullscreen mode Exit fullscreen mode

Using that same method for icons, you could apply a Twitter logo to any URLs that begin with Twitter's URL.

a[href^="https://twitter.com"] {
    ...styles
}
Enter fullscreen mode Exit fullscreen mode

This will target any anchor tag with an href that starts with the string "https://twitter.com".

Conversely, you can also check the end of a string for perhaps .pdf to find all the links to PDFs on the page.

a[href$=".pdf"] {
     ...styles
}
Enter fullscreen mode Exit fullscreen mode

There are so many handy recipes you can concoct with the attribute selectors. I wish more people knew about them and used them.

3. How to create multiple columns of flowing text or elements with CSS Multi-column

Image of multicolumn in 3 columns at desktop and 2 at tablet

Even before CSS Grid became available, we could do some minor work in columns outside of tables. CSS Multi-column is a specification that allows us to have text and elements flow through multiple columns.

You can use it with any amount of text and give it either a specific number of columns or a column-width to match against.

This can create interesting interstitial layouts in the middle of a blog post.

.column-content {
    column-width: 250px; /* Columns with max-width of 250px
/*  column-count: 2;        Always 2 columns */
    column-gap: 2rem;    /* Columns with 2rem of space in between */
}
Enter fullscreen mode Exit fullscreen mode

There's even more you can do with things like column-rule for borders, and column-span to create breaks in your columns for new headers.

A bright future for CSS with the past

While the second half of the 2010s has been amazing for new CSS (things like Flexbox and Grid), it's important to remember there are a lot of additional powers from the past.

The features mentioned in this post have been in browsers for years and don't get a lot of use. While experimenting with new cool toys this holiday season, don't forget to remember the past cool toys.

Question for the comments: What CSS feature do you think is underutilized by the industry as a whole?

Let me know in the comments (or on Twitter)

Stay up to date with Bryan

If you want to stay up to date with all the content I'm producing, be sure to follow me here, but also on other platforms as well.

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .