2021-01-21
1139
#css-in-js#react
Kasra Khosravi
32347
Jan 21, 2021 â‹… 4 min read

Styled-components vs. Emotion for handling CSS

Kasra Khosravi Founder at FeedbackOnSite.co.

Recent posts:

improving ux with scroll-select box

How to improve UX with a scroll-select box

The scroll-select box is a great tool for frontend developers to improve the user experience of their applications. Learn how to build a scrollable date picker that mimics the iOS style, but with the exemption of the <select> element.

Emmanuel Odioko
Feb 7, 2025 â‹… 10 min read
Deploying Next.js apps with Deno Deploy

Deploying Next.js apps with Deno Deploy

For those just getting started with deploying their first application, Deno Deploy’s simplicity might be exactly what you need; no complex configuration files to wrestle with or cloud concepts to master before getting your app live.

Emmanuel Odioko
Feb 6, 2025 â‹… 5 min read
A Guide To Object.groupBy: An Alternative To Array.reduce

A guide to Object.groupBy: An alternative to Array.reduce

Learn how Object.groupBy and Map.groupBy improve JavaScript data grouping over reduce, with performance benchmarks and comparisons.

Sebastian Weber
Feb 5, 2025 â‹… 4 min read
Best CI/CD tools for React Native

Best CI/CD tools for React Native

Get a high-level comparison of five of the most popular and well-used CI/CD tools for React Native apps, including the features they support.

Hussain Arif
Feb 5, 2025 â‹… 7 min read
View all posts

4 Replies to "Styled-components vs. Emotion for handling CSS"

  1. Interesting read 🙂

    I did the same comparison a month ago. I built two simple blog applications with a dark theme. One with Emotion and one with Styled Components. I used the object syntax for styling my React components

    Styled components and Emotion looked equal in any way. All I had to do was change the imports.

    Regarding performance and bundle size; there was barely any noticeable difference. The Emotion.js proof of concept was like 2kb smaller.

    Since I was already using Emotion.js for my React projects I chose to stick with it.

  2. Your styled-component examples import from ‘@emotion/styled’ which is misleading, but also highlights the fact that the API for these 2 libraries is nearly identical. It would have been helpful to have a technical breakdown comparing performance, bundle sizes, and limitations of each library.

  3. The styled-components examples have the wrong imports in the code blocks. You should correct these for clarity.

  4. Thanks Kasra for comparing them and thanks Peter for sharing your results too.

    Based on that, I would choose Styled Components because of the community, at least on GitHub, the numbers are double compared to Emotion.

Leave a Reply