JoshWComeau

šŸ” Going through the ā€œState of CSSā€ resultsā€¦

From
Josh W. Comeau
Reply-To
support@joshwcomeau.com
Sent
October 22, 2024

This issue of my newsletter was sent to newsletter subscribers.
Sign up to receive future issues!

Hi there!

A couple of days ago, the ā€œState of CSSā€ survey results(opens in new tab) were published. If youā€™re not familiar, State of CSS is an annual developer survey which has been running since 2019.

I went through the results and quite a few things stood out to me. So, in this email, I want to share what Iā€™ve discovered, and highlight the things I think are most important or interesting.

Link to this headingDemographics

The opening section is all about the demographics of the survey respondents. There are a few interesting findings around salary.

First, as you might expect, geography plays a huge role:

Graph showing the average salaries by country. US is the highest, with an average salary of $125k. Australia and Canada both average $90. Then, various European countries at 70k. Japan down at 50k.

If you spend time in online developer communities, youā€™ve probably seen people talking about eye-popping salaries and acting like everyone has them. This is a good reminder that, outside the US, very few developers earn $100k+.

This pair of charts highlights it even further:

Graph showing income brackets for devs both inside and outside the US. Inside the US, the most common salary range is $100k-$150k. Outside the US, the most common salary is $40k-60k, with only ~14% earning over 100k.

In the US, most respondents (~64%) earn $100k or more, but in the rest of the world, that number is only ~14%.

Interestingly, the next two countries with the highest salaries are Canada and Australia. Canada makes sense to me; we share timezones and a border with the US, so plenty of Canadians work remotely for US companies. Australia is on the other side of the world though! So maybe Australian companies pay really well?

Either way, these results reinforce something Iā€™ve believed for a long time: if your goal is to earn a lot of money as a software developer and you donā€™t live in the US, your best bet is to work remotely. I have a blog post that shares my own experience as an international remote worker(opens in new tab), and another post about how to find remote work(opens in new tab), which digs into all of the logistics.

The survey results include lots of ā€œcross-tabsā€, breaking down salary by other variables. For the most part, they match expectations (eg. salary tends to increase pretty dramatically with experience).

Depressingly, there is a stark wage gap between male and female survey respondents:

Graph showing salaries by gender. Men earn $70k, women earn $50k, non-binary / gender non-conforming earn $70k, ā€œNot listedā€ earn $50k. Weird win for non-binary folks, though itā€™s a small sample size (only 152 respondents). I would guess that there is a gap between male and non-binary salaries.

If you identify as male and have female co-workers, Iā€™d encourage you to see if thereā€™s a wage gap at your office, and to advocate for equal pay!

Of course, randomly DMing your co-workers with "Hey, my salary is $X" would be a bit weird šŸ˜…. And you definitely shouldnā€™t ask your female co-workers what their salary is! When I worked at Khan Academy, someone started a spreadsheet where the team could contribute their information anonymously, including their title and total compensation. This let us all see if there were disparities.

And if you find out that your co-workers arenā€™t being paid as much as you are, please advocate for them with your manager! Itā€™s so much more powerful when coming from someone else (itā€™s easy to dismiss someone raising concerns about their own salary, because who wouldnā€™t want more money).

Link to this headingUpcoming CSS features

Alright, onto the main attraction! Letā€™s talk about the CSS stuff.

The State of CSSā€™ format is to present the participant with a CSS feature and to ask whether theyā€™ve used it or not. They can also optionally express a sentiment. If theyā€™ve tried it, they can specify whether they liked it or not. If they havenā€™t, they can specify whether theyā€™re interested or not.

One of the most widely-used modern CSS features is the :has pseudo-class. 73% of developers have used it, and people seem pretty happy with it (38% positive and only 0.4% negative):

Graph showing the usage of :has. 73% of people have tried it, with 38% positive, 34% neutral, and 0.4% negative. 21% are interested in trying it. 3.6% have not heard of it.

Iā€™m not surprised by its popularity. Iā€™ve been using it myself for the past few months, and it blew my expectations out of the water. Itā€™s quickly become an indispensable part of my toolkit. I share all my favourite use cases in my blog post, ā€œThe Undeniable Utility of CSS :hasā€(opens in new tab).

Rather than highlight the popular features, though, I think it would be more valuable to showcase some of the underrated features, the hidden gems. šŸ˜„

For example, text-wrap: pretty! This feature has only been used by 1/4 of survey respondents, but itā€™s so handy. It lets us avoid ā€œorphansā€, words that sit alone on the final line of a paragraph.

I like to end my sentences with an emoji, but this can lead to awkward situations like this, where only the emoji linewraps:

A paragraph with 4 lines of text. The final ā€œlineā€ is a single emoji, looking stranded.

With text-wrap: pretty, it will ensure that the final line of text has at least two words, and shift things around so that the entire paragraph feels more balanced:

The same paragraph, except now the final line includes a regular word with the emoji. Feels much more balanced visually.

Avoiding orphans is the most obvious thing this property does, but really itā€™s a whole separate algorithm for managing line-wrapping, and it generally produces much more pleasant results. I recently added it to my CSS Reset(opens in new tab) to apply automatically to all paragraphs!

Another underappreciated feature is the ability to change the colorspace used for gradient interpolation. Only around 1 in 10 developers have taken advantage of this!

Graph showing the usage of ā€œInterpolation Color Spacesā€. 11.8% have tried it. 29.7% are familiar with it. 58.2% have never heard of it.

This feature can transform washed-out gradients like this one:

A gradient that goes from yellow to blue, and becomes gray and muddy in the middle

ā€¦into this one:

A gradient that goes from yellow to blue, but has a nice pink/purple transition

I have a blog post about gradient interpolation(opens in new tab) that explains how this all works. Back when I published this post, however, we had to manually calculate the stops using JavaScript. Now we can do it with this handy new syntax:

.elem {
  /* Fallback for older browsers: */
  background: linear-gradient(yellow, blue);

  /* Fancy new value: */
  background: linear-gradient(in oklch, yellow, blue);
}

Browser support is around 88%(opens in new tab), so we should still provide a fallback for older browsers. The gradient will be a bit less crisp for ~12% of users, but I think thatā€™s fine in most circumstances.

Next up, the prefers-reduced-motion media query:

Graph showing the usage of ā€œprefers-reduced-motionā€. 43.5% have used it, 31.3% are familiar, 24.6% have never heard of it

I was surprised to see that only ~44% of developers have used it. This feature is essential when doing any sort of animation that involves motion, to make sure we arenā€™t causing problems for folks who have vestibular issues. I have a blog post all about this(opens in new tab) (the blog post is React-specific, but the first half of the post doesnā€™t mention React at all and contains everything you need to know to use it in a vanilla CSS context).

Finally, thereā€™s backdrop-filter:

Graph showing the usage of ā€œbackdrop-filterā€. 59% have used it, 18.1% are familiar, 22.5% have never heard of it

This property isnā€™t exactly obscure, but I was surprised to see that almost 40% of developers have never used it!

Itā€™s similar to the filter property, except instead of applying the filter to the element itself, it applies it to everything behind the element. This allows us to create frosted-glass effects, like on my blogā€™s header:

screen recording of my blog's homepage, featuring a colorful rainbow. As the rainbow disappears behind the header, it gets blurry, as if seen through frosted glass

(Sorry for the poor quality of this GIF! I'm trying not to consume too much of your bandwidth ā¤ļø)

(I should also note, I'm using this property in a slightly more advanced way here, using Arturā€™s realistic glass technique(opens in new tab). I'm planning on writing a blog post all about this soon!)

Link to this headingCSS Frameworks

So, the big story with CSS libraries over the past few years has been Tailwind.

I have complicated feelings about Tailwind. In terms of the developer experience, I find atomic CSS absolutely detestable šŸ˜…. I also have some concerns about Tailwindā€™s performance in large projects.

On the other hand: most of my quibbles are totally subjective, and exacerbated by my own inexperience with Tailwind. Ergonomics aside, I think Tailwind solves the most important problems, in terms of scoping and style isolation. And I like that front-end developers are getting excited about CSS!

Iā€™ve been wondering for a few years what Tailwindā€™s ceiling is. Letā€™s see what we can learn from this yearā€™s survey results:

Answers to the question ā€œWhich CSS frameworks do you use?ā€, showing 75% Tailwind, 54% Bootstrap, 13% Ant Design, 13% Materialize CSS, and then several options under 10%

75% usage seems like a lot, but this isnā€™t the full story. Notice the "50%" in the bottom left corner: thatā€™s the percentage of survey respondents who answered this question.

When I answered the survey this year, I skipped this question because I donā€™t use any of these tools. So in terms of total usage, itā€™s 37.5% (75% of the 50% of respondents who answered this question).

How does that compare to previous years? Itā€™s tricky: the survey format changed between this year and previous years. The closest value I was able to find is that 37.4% of survey respondents used Tailwind in 2023, but I'm skeptical of this number since a much larger percentage of respondents answered this question (74% to only 50%).

My hunch is that Tailwind is approaching its ceiling in terms of total usage, but I'll have to wait until next year, to have a true apples-to-apples comparison. Whether itā€™s plateaued or still growing, however, itā€™s clear that Tailwind isnā€™t going away anytime soon.

Link to this headingCSS-in-JS

My favourite way to write CSS is with the styled interface provided in libraries like styled-components, Emotion, and Panda CSS. And this yearā€™s results are super interesting:

Answers to the question ā€œWhich CSS-in-JS libraries do you use?ā€, showing 61% CSS Modules, 59% Styled Components, 25% Emotion, 20% Styled JSX, and several other options under 10%

styled-components continues to be one of the most popular options, only slightly behind CSS Modules, with 59% usage. Only 36% of respondents answered this question, but that makes sense to me, given that these tools are React-specific, and this is a survey about CSS.

This number has actually grown since last year (when it was 49.9%), though again, I'm a bit skeptical of this since the format is different. Either way, itā€™s clear that a large percentage of the community still uses these tools, and I wish there was more enthusiasm around continuing to support these developers and their projects!

Link to this headingCSS Usage

The next part of the survey looks at how developers use CSS.

I found this graph pretty surprising:

Answers to the question ā€œWhich form factors or environments do you test on?ā€, showing 99% desktop, 67% smartphone, 43% tablet, 28% desktop with keyboard only, 27% testing tools (like Axe), 25% feature phone, 19% screen reader, 10% print, and several options under 10%

Apparently, 1/3rd of survey respondents donā€™t test their work on mobile? This is kinda baffling; most internet traffic these days is mobile, so I don't know how you avoid testing on mobile!

I was also a little disheartened to see how few developers test the accessibility of their work:

  • 28% test using keyboard navigation on desktop
  • 27% test using devtools like aXe
  • 19% test using screen readers

Maybe the question was phrased in a way that some people didnā€™t understand. Iā€™m skeptical about that mobile number. Hopefully, all of these numbers are higher in the real world!

Finally, thereā€™s this graph:

Graph showing how happy people are with CSS, on a scale from 0 (totally unhappy) to 4 (couldn't be happier). In 2020, this number was around 2.8. It has sloped gently upwards, and is now 3.1.

This one makes me happy. So many people have been working on CSS over the past few years, from specification authors to browser engineers. It feels like our community is really appreciating those efforts!

Those are the things I found interesting, but you can go through the results yourself(opens in new tab) to see what stands out to you!

With surveys like this, itā€™s always important to keep in mind that weā€™re not seeing the whole picture. Most developers donā€™t hang out in online developer communities at all, and have no idea that this survey exists! So we should be careful not to put too much faith in the results.

One of the underrated benefits of participating in surveys like this is that it helps teach you about the language! The State of HTML survey(opens in new tab) is running right now, and I learned about a pretty cool upcoming feature(opens in new tab) through it!

Thatā€™s all I have for you today. Hope your week is off to a great start!

-Josh

PS: Speaking of participating in surveys, a reminder to my American friends that the US federal election is just around the corner! If you have a preference about which person becomes the next president, now is the time to do something about it.

Many states offer early in-person voting. This is a great way to avoid the lines and make sure you get your vote cast. For more information, check out vote.orgā€™s early voting calendar(opens in new tab).

This issue of my newsletter was sent to newsletter subscribers.
Sign up to receive future issues!