-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpath---tags-css-in-js-733b0b6ae26b107cf272.js
3 lines (3 loc) · 198 KB
/
path---tags-css-in-js-733b0b6ae26b107cf272.js
1
2
3
webpackJsonp([0xa78ed9a99209],{509:function(e,a){e.exports={pathContext:{tags:["tech stack","colophon","about","intro","gatsby","react","javascript","css","css in js","component styling","styled-components","glamorous","graphql","node"],tag:[{excerpt:"I’m a frontend developer specializing in all things JavaScript. Throughout my career, I’ve done a fair bit of everything: Angular, React, jQuery, you name it. Of course, I’ve also done a fair bit of everything in CSS land, whether it’s vanilla CSS…",html:'<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="0"\n title=""\n src="/interpreter/static/01-0-b1fbc18c3ebdc59d31748d1555f3e50a-83a8b.png"\n srcset="/interpreter/static/01-0-b1fbc18c3ebdc59d31748d1555f3e50a-8992e.png 163w,\n/interpreter/static/01-0-b1fbc18c3ebdc59d31748d1555f3e50a-ae0a7.png 325w,\n/interpreter/static/01-0-b1fbc18c3ebdc59d31748d1555f3e50a-83a8b.png 650w,\n/interpreter/static/01-0-b1fbc18c3ebdc59d31748d1555f3e50a-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>I’m a frontend developer specializing in all things JavaScript. Throughout my career, I’ve done a fair bit of everything: Angular, React, jQuery, you name it. Of course, I’ve also done a fair bit of everything in CSS land, whether it’s vanilla CSS, LESS, SASS, CSS Modules, and (of course) the gamut of CSS in JS solutions. I’m from little ol’ Omaha, Nebraska, which I think most people looks a bit like this.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="about me"\n title=""\n src="/interpreter/static/02-about-me-ca17484b9a37dfb8926469b2fa32f0ce-83a8b.png"\n srcset="/interpreter/static/02-about-me-ca17484b9a37dfb8926469b2fa32f0ce-8992e.png 163w,\n/interpreter/static/02-about-me-ca17484b9a37dfb8926469b2fa32f0ce-ae0a7.png 325w,\n/interpreter/static/02-about-me-ca17484b9a37dfb8926469b2fa32f0ce-83a8b.png 650w,\n/interpreter/static/02-about-me-ca17484b9a37dfb8926469b2fa32f0ce-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="nebraska actual"\n title=""\n src="/interpreter/static/03-nebraska-actual-29ffa558d8876c596975d258325ad683-83a8b.png"\n srcset="/interpreter/static/03-nebraska-actual-29ffa558d8876c596975d258325ad683-8992e.png 163w,\n/interpreter/static/03-nebraska-actual-29ffa558d8876c596975d258325ad683-ae0a7.png 325w,\n/interpreter/static/03-nebraska-actual-29ffa558d8876c596975d258325ad683-83a8b.png 650w,\n/interpreter/static/03-nebraska-actual-29ffa558d8876c596975d258325ad683-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>I work at a great company called Object Partners. We specialize in JVM and frontend development of all sorts. Between Omaha, Minneapolis, and Chicago, we have about 100 excellent consultants.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="object partners"\n title=""\n src="/interpreter/static/04-object-partners-973c2d8b90e61e6b47537ad232dd341b-83a8b.png"\n srcset="/interpreter/static/04-object-partners-973c2d8b90e61e6b47537ad232dd341b-8992e.png 163w,\n/interpreter/static/04-object-partners-973c2d8b90e61e6b47537ad232dd341b-ae0a7.png 325w,\n/interpreter/static/04-object-partners-973c2d8b90e61e6b47537ad232dd341b-83a8b.png 650w,\n/interpreter/static/04-object-partners-973c2d8b90e61e6b47537ad232dd341b-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Every presentation has this prerequisite sponsors slide, but they truly deserve so much credit. Without their support, we wouldn’t have all gotten together for this great conference, so it is <em>sincerely</em> appreciated. Thank you so much!</p>\n<p>❤️</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="sponsors"\n title=""\n src="/interpreter/static/05-sponsors-a830cb18e795252ef3539f8a0f4b8110-83a8b.png"\n srcset="/interpreter/static/05-sponsors-a830cb18e795252ef3539f8a0f4b8110-8992e.png 163w,\n/interpreter/static/05-sponsors-a830cb18e795252ef3539f8a0f4b8110-ae0a7.png 325w,\n/interpreter/static/05-sponsors-a830cb18e795252ef3539f8a0f4b8110-83a8b.png 650w,\n/interpreter/static/05-sponsors-a830cb18e795252ef3539f8a0f4b8110-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>I feel like some of you <em>may</em> have a pretty negative perception of CSS in JS, or at least not an overtly positive perception. This can be for a variety of reasons, but I think paramount for some is that it goes against the “separation of concerns” that have been ingrained in our minds and regularly re-enforced. It can feel weird, it can feel unclean, and it can even feel like a solution looking for a problem.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="from here"\n title=""\n src="/interpreter/static/06-from-here-1898ec85332b65a355fcd0aae3a64685-83a8b.png"\n srcset="/interpreter/static/06-from-here-1898ec85332b65a355fcd0aae3a64685-8992e.png 163w,\n/interpreter/static/06-from-here-1898ec85332b65a355fcd0aae3a64685-ae0a7.png 325w,\n/interpreter/static/06-from-here-1898ec85332b65a355fcd0aae3a64685-83a8b.png 650w,\n/interpreter/static/06-from-here-1898ec85332b65a355fcd0aae3a64685-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>My goal is to take you from this initial <em>possibly</em> negative stance to cautious skepticism. I hope you leave here with an understanding of why CSS in JS exists, and how it can solve some very real developmental problems. Perhaps it might not be the perfect fit for your application at this point, but you can understand why someone else would adopt some of these technologies.</p>\n<p>A stretch goal is that many of you will leave here fully convinced that CSS in JS is the solution to some of your CSS problems, and you’ll adopt these techniques for your next application.</p>\n<h2 id="agenda"><a href="#agenda" aria-hidden="true" class="anchor"><svg aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Agenda</h2>\n<ul>\n<li>\n<p>Discussion of the problems of CSS</p>\n</li>\n<li>\n<p>Defining what CSS in JS is, and how it can solve some of these problems</p>\n</li>\n<li>\n<p>Discussing some various CSS in JS libraries, and real world examples of the usage of these</p>\n</li>\n<li>\n<p>Finishing up with some discussion of drawbacks of CSS in JS and some quick demos</p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="to here"\n title=""\n src="/interpreter/static/07-to-here-10cde59ff47df9958225f63e5f3cdf51-83a8b.png"\n srcset="/interpreter/static/07-to-here-10cde59ff47df9958225f63e5f3cdf51-8992e.png 163w,\n/interpreter/static/07-to-here-10cde59ff47df9958225f63e5f3cdf51-ae0a7.png 325w,\n/interpreter/static/07-to-here-10cde59ff47df9958225f63e5f3cdf51-83a8b.png 650w,\n/interpreter/static/07-to-here-10cde59ff47df9958225f63e5f3cdf51-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Let’s start with a brief discussion of some of the problems of CSS. An important caveat here, these problems tend to be focused on real-world examples that every-day developers have run into, or have run into without even realizing it and resorting to hack-y work arounds. This is not to say that problems “at scale” are not important, but if we can narrow the scope to problems that every-day developers, and myself, have faced, we can more clearly define the problems in more approachable terms and concepts. In illustrating these real-world problems, the foundational basis for the creation of these CSS in JS techniques will be made evident.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="the problems"\n title=""\n src="/interpreter/static/08-the-problems-fa6db80ef14cfc6d39cf44af42f90402-83a8b.png"\n srcset="/interpreter/static/08-the-problems-fa6db80ef14cfc6d39cf44af42f90402-8992e.png 163w,\n/interpreter/static/08-the-problems-fa6db80ef14cfc6d39cf44af42f90402-ae0a7.png 325w,\n/interpreter/static/08-the-problems-fa6db80ef14cfc6d39cf44af42f90402-83a8b.png 650w,\n/interpreter/static/08-the-problems-fa6db80ef14cfc6d39cf44af42f90402-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>For these first examples, let’s say that we’re a team of front-end developers working on a component library to be used throughout a company’s internal application suite. We get business requirements from users and they’re filtered through our UX department, who weeds these out and gives us the truly important requirements.</p>\n<p>Our first task from the UX team to design a button component that has a hover state and raises slightly on hover. We design and build this with vanilla CSS and HTML. This button looks great, meets every current need we have, and the code is quite succinct, to boot. This is a <em>great</em> component!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="first button"\n title=""\n src="/interpreter/static/09-first-button-5bff0108aa2868c0761df3babf65b777-83a8b.png"\n srcset="/interpreter/static/09-first-button-5bff0108aa2868c0761df3babf65b777-8992e.png 163w,\n/interpreter/static/09-first-button-5bff0108aa2868c0761df3babf65b777-ae0a7.png 325w,\n/interpreter/static/09-first-button-5bff0108aa2868c0761df3babf65b777-83a8b.png 650w,\n/interpreter/static/09-first-button-5bff0108aa2868c0761df3babf65b777-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Our UX team makes another request of our team. We now need a secondary style, and the previous button will be considered the primary style. So… we add this secondary class, we complete the objective, and we’re still feeling fairly good about our button component.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="second button"\n title=""\n src="/interpreter/static/10-second-button-b7eda9637902ec22b11c6ad608d75cd4-83a8b.png"\n srcset="/interpreter/static/10-second-button-b7eda9637902ec22b11c6ad608d75cd4-8992e.png 163w,\n/interpreter/static/10-second-button-b7eda9637902ec22b11c6ad608d75cd4-ae0a7.png 325w,\n/interpreter/static/10-second-button-b7eda9637902ec22b11c6ad608d75cd4-83a8b.png 650w,\n/interpreter/static/10-second-button-b7eda9637902ec22b11c6ad608d75cd4-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>We get another request that the button is far too large for certain applications, and the request has been made that we add a button with reduced padding, font-size, etc so more can be displayed on screen. We add this <code>tiny</code> class, and we complete the business requirements. This is fine…</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="third button"\n title=""\n src="/interpreter/static/11-third-button-c2c759cfcfd593c6ae07837fb4bc5cbe-83a8b.png"\n srcset="/interpreter/static/11-third-button-c2c759cfcfd593c6ae07837fb4bc5cbe-8992e.png 163w,\n/interpreter/static/11-third-button-c2c759cfcfd593c6ae07837fb4bc5cbe-ae0a7.png 325w,\n/interpreter/static/11-third-button-c2c759cfcfd593c6ae07837fb4bc5cbe-83a8b.png 650w,\n/interpreter/static/11-third-button-c2c759cfcfd593c6ae07837fb4bc5cbe-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>We get a final request that the button neds to a have a hover state for accessibility and more intuitive feedback on desktop screens. We add this class, and our button is “completed,” for now. This is <em>not</em> fine 😫</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="fourth button"\n title=""\n src="/interpreter/static/12-fourth-button-f5d5908dc0a38d52a1eff144eda56b7a-83a8b.png"\n srcset="/interpreter/static/12-fourth-button-f5d5908dc0a38d52a1eff144eda56b7a-8992e.png 163w,\n/interpreter/static/12-fourth-button-f5d5908dc0a38d52a1eff144eda56b7a-ae0a7.png 325w,\n/interpreter/static/12-fourth-button-f5d5908dc0a38d52a1eff144eda56b7a-83a8b.png 650w,\n/interpreter/static/12-fourth-button-f5d5908dc0a38d52a1eff144eda56b7a-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="the globals"\n title=""\n src="/interpreter/static/13-the-globals-be69fd3cbbe98db7835c23f48b88c94d-83a8b.png"\n srcset="/interpreter/static/13-the-globals-be69fd3cbbe98db7835c23f48b88c94d-8992e.png 163w,\n/interpreter/static/13-the-globals-be69fd3cbbe98db7835c23f48b88c94d-ae0a7.png 325w,\n/interpreter/static/13-the-globals-be69fd3cbbe98db7835c23f48b88c94d-83a8b.png 650w,\n/interpreter/static/13-the-globals-be69fd3cbbe98db7835c23f48b88c94d-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p> Let’s consider the usage of this button component by a developer who comes on the project long down the road, far after the team that designed the component has left for greener pastures. This developer is relatively inexperienced, and is just trying to add in style that makes a link look like a button. This seemingly simple task is more complicated than it appears at first glance. These globals make the job <em>far</em> more diffiult than expected, and the developer resorts to messy hacks and the use of <code>!important</code> in an effort to ship and meet a deadline.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="global problems"\n title=""\n src="/interpreter/static/14-global-problems-efc9f88347058f4c18d091c005e776a5-83a8b.png"\n srcset="/interpreter/static/14-global-problems-efc9f88347058f4c18d091c005e776a5-8992e.png 163w,\n/interpreter/static/14-global-problems-efc9f88347058f4c18d091c005e776a5-ae0a7.png 325w,\n/interpreter/static/14-global-problems-efc9f88347058f4c18d091c005e776a5-83a8b.png 650w,\n/interpreter/static/14-global-problems-efc9f88347058f4c18d091c005e776a5-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>But wait… we’ve invented techniques to solve these problems!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="but wait"\n title=""\n src="/interpreter/static/15-but-wait-8783d3472cfa53637a49def8b3c7a1a1-83a8b.png"\n srcset="/interpreter/static/15-but-wait-8783d3472cfa53637a49def8b3c7a1a1-8992e.png 163w,\n/interpreter/static/15-but-wait-8783d3472cfa53637a49def8b3c7a1a1-ae0a7.png 325w,\n/interpreter/static/15-but-wait-8783d3472cfa53637a49def8b3c7a1a1-83a8b.png 650w,\n/interpreter/static/15-but-wait-8783d3472cfa53637a49def8b3c7a1a1-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>CSS naming methodologies like BEM exist to solve this exact problem re: name collision and CSS globals. Also consider other solutions like Atomic CSS, OOCSS, SMACSS, SUITCSS, Object-oriented CSS, etc.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="bem"\n title=""\n src="/interpreter/static/16-bem-cd2d8e4883e8b55a3afdc37ab619f23f-83a8b.png"\n srcset="/interpreter/static/16-bem-cd2d8e4883e8b55a3afdc37ab619f23f-8992e.png 163w,\n/interpreter/static/16-bem-cd2d8e4883e8b55a3afdc37ab619f23f-ae0a7.png 325w,\n/interpreter/static/16-bem-cd2d8e4883e8b55a3afdc37ab619f23f-83a8b.png 650w,\n/interpreter/static/16-bem-cd2d8e4883e8b55a3afdc37ab619f23f-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>I am very much not a fan of these methodologies. They introduce cognitive overhead and introduce naming concerns. Is this particular thing a modifier? An element? A block? Naming is already notoriously hard; this technique certainly does solve the class name collision problem, but I contend it imposes extraneous concerns on behalf of the developer that can be solved in other, cleaner ways (as we’ll see soon).</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="run"\n title=""\n src="/interpreter/static/17-run-8f5ac6ba4b750abe9def79e933a97f97-83a8b.png"\n srcset="/interpreter/static/17-run-8f5ac6ba4b750abe9def79e933a97f97-8992e.png 163w,\n/interpreter/static/17-run-8f5ac6ba4b750abe9def79e933a97f97-ae0a7.png 325w,\n/interpreter/static/17-run-8f5ac6ba4b750abe9def79e933a97f97-83a8b.png 650w,\n/interpreter/static/17-run-8f5ac6ba4b750abe9def79e933a97f97-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="safety through-automation"\n title=""\n src="/interpreter/static/18-safety-through-automation-4e498ca52628fe0f5a85c34b9bacbf20-83a8b.png"\n srcset="/interpreter/static/18-safety-through-automation-4e498ca52628fe0f5a85c34b9bacbf20-8992e.png 163w,\n/interpreter/static/18-safety-through-automation-4e498ca52628fe0f5a85c34b9bacbf20-ae0a7.png 325w,\n/interpreter/static/18-safety-through-automation-4e498ca52628fe0f5a85c34b9bacbf20-83a8b.png 650w,\n/interpreter/static/18-safety-through-automation-4e498ca52628fe0f5a85c34b9bacbf20-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Consider this quote by Kent C. Dodds. Why would we not use tooling to automate trivial naming concerns? Development is oftentimes all about automating hard problems, and is naming not one of the most (unecessarily) difficult ones we face?</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="hard stuff"\n title=""\n src="/interpreter/static/19-hard-stuff-5e6bae4d5b66836b7cd47c5205a302ce-83a8b.png"\n srcset="/interpreter/static/19-hard-stuff-5e6bae4d5b66836b7cd47c5205a302ce-8992e.png 163w,\n/interpreter/static/19-hard-stuff-5e6bae4d5b66836b7cd47c5205a302ce-ae0a7.png 325w,\n/interpreter/static/19-hard-stuff-5e6bae4d5b66836b7cd47c5205a302ce-83a8b.png 650w,\n/interpreter/static/19-hard-stuff-5e6bae4d5b66836b7cd47c5205a302ce-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>But others still will note that this problem of globals has been solved with tooling in other areas. CSS Modules and Shadow DOM (a staged spec introduced in web components to isolate styling to a particular subset of the DOM) <em>both</em> are intended to solve this problem.</p>\n<p>CSS Modules is an implementation of CSS in JS, so if you leave here with nothing else, consider integrating CSS Modules support into your application. It’ll generate a unique hash based on a user supplied class name. Shadow modules are similarly going to be great, but I’m not quite sure they’re ready for primetime yet (nor are web components <em>quite</em> there in my opinion).</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="alternatives"\n title=""\n src="/interpreter/static/20-alternatives-91fe98c79e11d63e562a388896838f36-83a8b.png"\n srcset="/interpreter/static/20-alternatives-91fe98c79e11d63e562a388896838f36-8992e.png 163w,\n/interpreter/static/20-alternatives-91fe98c79e11d63e562a388896838f36-ae0a7.png 325w,\n/interpreter/static/20-alternatives-91fe98c79e11d63e562a388896838f36-83a8b.png 650w,\n/interpreter/static/20-alternatives-91fe98c79e11d63e562a388896838f36-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Shadow DOM, and web components as a whole, are certainly something that I think will continue to grow in popularity in the coming months and years. That said, the web component implementations are still slightly in flux, and for full browser support, you’ll certainly have to ship a polyfill.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="shadow dom-support"\n title=""\n src="/interpreter/static/21-shadow-dom-support-178dea1d30838a7b090ae876340a50d1-83a8b.png"\n srcset="/interpreter/static/21-shadow-dom-support-178dea1d30838a7b090ae876340a50d1-8992e.png 163w,\n/interpreter/static/21-shadow-dom-support-178dea1d30838a7b090ae876340a50d1-ae0a7.png 325w,\n/interpreter/static/21-shadow-dom-support-178dea1d30838a7b090ae876340a50d1-83a8b.png 650w,\n/interpreter/static/21-shadow-dom-support-178dea1d30838a7b090ae876340a50d1-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The bigger your application gets (and the more CSS you write), the more globals you will create which is quite simply making your application harder to maintain and use. In order to work around these scaling issues, naming strategies or tools—LESS, SASS, etc.—are often utilized.</p>\n<p>CSS in JS solves this problems cleanly, clearly, and simply.</p>\n<p>Also I’d like to note here that, in general, I tend to think “does not scale,” is a perjorative used by people who are just not fans of that particular technology. That is not the case here though, as most advocates of CSS in JS <em>love</em> CSS. You’ll also see soon that when you’re writing CSS in JS, you’re using all the functionality that we know and love in CSS.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="it does-not-scale"\n title=""\n src="/interpreter/static/22-it-does-not-scale-1dec955f9e822381d0a58351dda4945f-83a8b.png"\n srcset="/interpreter/static/22-it-does-not-scale-1dec955f9e822381d0a58351dda4945f-8992e.png 163w,\n/interpreter/static/22-it-does-not-scale-1dec955f9e822381d0a58351dda4945f-ae0a7.png 325w,\n/interpreter/static/22-it-does-not-scale-1dec955f9e822381d0a58351dda4945f-83a8b.png 650w,\n/interpreter/static/22-it-does-not-scale-1dec955f9e822381d0a58351dda4945f-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Your class names and styles (i.e. <code>.css</code> files) are separately located to what is being styled, typically JSX with <code>className</code> or in non-React projects, as separate HTML files. Additionally, as previously mentioned, as CSS is global by default, your styles could be styling unrelated functionality in your application. Jointly, these two concerns make it incredibly difficult to re-factor unused CSS.</p>\n<p>Removing styles can be a spooky endeavour 👻, and many regression tests, QA, or manual testing is often required to validate with certainty that only certain functionality was impacted. Each of these techniques requires manual testing and validation, and is not something that every developer has available to them.</p>\n<p>CSS in JS gives you confidence that by removing this particular component, you’re removing style code applicable to this component <em>only</em>.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="dead code-elimination"\n title=""\n src="/interpreter/static/23-dead-code-elimination-e262a4ad50b63007003b171aee9e86e5-83a8b.png"\n srcset="/interpreter/static/23-dead-code-elimination-e262a4ad50b63007003b171aee9e86e5-8992e.png 163w,\n/interpreter/static/23-dead-code-elimination-e262a4ad50b63007003b171aee9e86e5-ae0a7.png 325w,\n/interpreter/static/23-dead-code-elimination-e262a4ad50b63007003b171aee9e86e5-83a8b.png 650w,\n/interpreter/static/23-dead-code-elimination-e262a4ad50b63007003b171aee9e86e5-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Theming, stylistic concerns (e.g. padding, line-height, etc.), and other possibly shared constants are a natural and intuitive fit to be colocated within your JavaScript. Want to re-use that branding color in your header for a button? Sure makes sense to share that with your CSS and JS. Media query breakpoints? Another intuitive and obvious fit.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="sharing constants"\n title=""\n src="/interpreter/static/24-sharing-constants-ca3771fc4b28fb4d4e871ed07bbb0d15-83a8b.png"\n srcset="/interpreter/static/24-sharing-constants-ca3771fc4b28fb4d4e871ed07bbb0d15-8992e.png 163w,\n/interpreter/static/24-sharing-constants-ca3771fc4b28fb4d4e871ed07bbb0d15-ae0a7.png 325w,\n/interpreter/static/24-sharing-constants-ca3771fc4b28fb4d4e871ed07bbb0d15-83a8b.png 650w,\n/interpreter/static/24-sharing-constants-ca3771fc4b28fb4d4e871ed07bbb0d15-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Oftentimes, I know I’ve needed to share things like colors, breakpoints, etc. between my CSS and JavaScript. I’ve oftentimes resorted to using a brittle build process, which inevitably can fall out of sync or require tweaks at some later point.</p>\n<p>Why not use one source of truth for all application constants, and why not make that source of truth a JavaScript file with CSS in JS? Sure makes sense to me!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="sharing constants-example"\n title=""\n src="/interpreter/static/25-sharing-constants-example-cce7156abf3a1cbc2ca02850606a3298-83a8b.png"\n srcset="/interpreter/static/25-sharing-constants-example-cce7156abf3a1cbc2ca02850606a3298-8992e.png 163w,\n/interpreter/static/25-sharing-constants-example-cce7156abf3a1cbc2ca02850606a3298-ae0a7.png 325w,\n/interpreter/static/25-sharing-constants-example-cce7156abf3a1cbc2ca02850606a3298-83a8b.png 650w,\n/interpreter/static/25-sharing-constants-example-cce7156abf3a1cbc2ca02850606a3298-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Much credit where credit is due, many of these problems were identified in a formative CSS in JS presentation by <a href="https://twitter.com/vjeux">Christopher Chedeau</a> (a developer at Facebook), who delivered a great presentation highlighting many of these issues way back in 2014!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="facebook problems"\n title=""\n src="/interpreter/static/26-facebook-problems-30b37796995fdbbea2bcdefb7920aaec-83a8b.png"\n srcset="/interpreter/static/26-facebook-problems-30b37796995fdbbea2bcdefb7920aaec-8992e.png 163w,\n/interpreter/static/26-facebook-problems-30b37796995fdbbea2bcdefb7920aaec-ae0a7.png 325w,\n/interpreter/static/26-facebook-problems-30b37796995fdbbea2bcdefb7920aaec-83a8b.png 650w,\n/interpreter/static/26-facebook-problems-30b37796995fdbbea2bcdefb7920aaec-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Early in my career, I was in a meeting where I criticized a proposed solution that I thought to be poor, and left it at that. Another person in the meeting said “If you can’t bring anything to the table, then don’t say anything at all.” While the character of the message was delivered imperfectly, the content of the message still resonates with me. It’s easy to criticize something. It’s far, far harder to criticize something, and propose something better, or that could be better.</p>\n<p>At this point, the discussion will shift into what CSS in JS is, and how it can fix some of these aforementioned problems. In other words, let’s bring something to the table!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="benefits intro"\n title=""\n src="/interpreter/static/27-benefits-intro-cb5196bc690b85743a91570dd3f365d8-83a8b.png"\n srcset="/interpreter/static/27-benefits-intro-cb5196bc690b85743a91570dd3f365d8-8992e.png 163w,\n/interpreter/static/27-benefits-intro-cb5196bc690b85743a91570dd3f365d8-ae0a7.png 325w,\n/interpreter/static/27-benefits-intro-cb5196bc690b85743a91570dd3f365d8-83a8b.png 650w,\n/interpreter/static/27-benefits-intro-cb5196bc690b85743a91570dd3f365d8-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>It’s not CSS in JS <em>or</em> CSS. It’s CSS in JS <em>with</em> CSS.</p>\n<p>The CSS you’ve formerly written can continue to be written with this paradigm shift. The best parts of CSS are maintained, and, for the most part, the ills of CSS are remedied with these new approaches.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="not broken"\n title=""\n src="/interpreter/static/28-not-broken-d3629887e93a711793bcb09a860bf148-83a8b.png"\n srcset="/interpreter/static/28-not-broken-d3629887e93a711793bcb09a860bf148-8992e.png 163w,\n/interpreter/static/28-not-broken-d3629887e93a711793bcb09a860bf148-ae0a7.png 325w,\n/interpreter/static/28-not-broken-d3629887e93a711793bcb09a860bf148-83a8b.png 650w,\n/interpreter/static/28-not-broken-d3629887e93a711793bcb09a860bf148-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Maybe by recontextualizing the problem and bringing the power of JavaScript to CSS we can solve some true problems with CSS.</p>\n<p>Maybe there’s actually some validity to this practice.</p>\n<p>Maybe it can really improve the quality and maintainability of your application.</p>\n<p>Maybe we will see!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="but maybe-it-is"\n title=""\n src="/interpreter/static/29-but-maybe-it-is-2d0f9cafcc11b614484c2e1021c468c6-83a8b.png"\n srcset="/interpreter/static/29-but-maybe-it-is-2d0f9cafcc11b614484c2e1021c468c6-8992e.png 163w,\n/interpreter/static/29-but-maybe-it-is-2d0f9cafcc11b614484c2e1021c468c6-ae0a7.png 325w,\n/interpreter/static/29-but-maybe-it-is-2d0f9cafcc11b614484c2e1021c468c6-83a8b.png 650w,\n/interpreter/static/29-but-maybe-it-is-2d0f9cafcc11b614484c2e1021c468c6-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p><em>But</em>, <em>But</em>, <em>But</em>, you exclaim! This goes against everything we’ve been taught about seperation of concerns. HTML in my JS was already enough of a shift, but this is just too much!</p>\n<p>It goes against this hyper-modularization we’ve seen in the JavaScript ecosystem.</p>\n<p>It just <em>feels</em> wrong.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="lesh tweet"\n title=""\n src="/interpreter/static/30-lesh-tweet-2a07cdc492855c5b083a33076d144b7e-83a8b.png"\n srcset="/interpreter/static/30-lesh-tweet-2a07cdc492855c5b083a33076d144b7e-8992e.png 163w,\n/interpreter/static/30-lesh-tweet-2a07cdc492855c5b083a33076d144b7e-ae0a7.png 325w,\n/interpreter/static/30-lesh-tweet-2a07cdc492855c5b083a33076d144b7e-83a8b.png 650w,\n/interpreter/static/30-lesh-tweet-2a07cdc492855c5b083a33076d144b7e-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>However… seperation of concerns is not the same as seperation of technologies. It is incredibly likely that the rendering of a component will require intermingling between HTML, CSS, and JavaScript, and if we can make this intermingling as clean as possible, that’s a win for code clarity and maintainability, not a loss.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="seperation of-concerns"\n title=""\n src="/interpreter/static/31-seperation-of-concerns-9b96cd9af72f4fe75f362e95d8fe1361-83a8b.png"\n srcset="/interpreter/static/31-seperation-of-concerns-9b96cd9af72f4fe75f362e95d8fe1361-8992e.png 163w,\n/interpreter/static/31-seperation-of-concerns-9b96cd9af72f4fe75f362e95d8fe1361-ae0a7.png 325w,\n/interpreter/static/31-seperation-of-concerns-9b96cd9af72f4fe75f362e95d8fe1361-83a8b.png 650w,\n/interpreter/static/31-seperation-of-concerns-9b96cd9af72f4fe75f362e95d8fe1361-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Consider this great slide by <a href="https://twitter.com/areaweb">Cristiano Rastelli</a>.</p>\n<p>The component driven model blurs the line between HTML, CSS, and JavaScript beacuse there will inevitably be shared concerns between a single component which is composed of these “disparate” parts.</p>\n<p>Consider also Vue’s single file components, which are a perfect encapsulation of this model.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="seperation of-concerns-image"\n title=""\n src="/interpreter/static/32-seperation-of-concerns-image-fdc023a930634b0e90efc577635217fc-83a8b.png"\n srcset="/interpreter/static/32-seperation-of-concerns-image-fdc023a930634b0e90efc577635217fc-8992e.png 163w,\n/interpreter/static/32-seperation-of-concerns-image-fdc023a930634b0e90efc577635217fc-ae0a7.png 325w,\n/interpreter/static/32-seperation-of-concerns-image-fdc023a930634b0e90efc577635217fc-83a8b.png 650w,\n/interpreter/static/32-seperation-of-concerns-image-fdc023a930634b0e90efc577635217fc-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Let’s start with a definition by contradiction, or in other words, what CSS in JS is <em>not</em>.</p>\n<p>CSS in JS is not, or at least not exclusively, inline styles. While inline styles are certainly an example of what CSS in JS can look like, they’re not necessarily the best implementation for a variety of reasons. First and foremost, only a subset of CSS is supported, so things like pseudo styles (<code>:hover</code>, <code>:focus</code>, etc.), media queries, and a number of other useful and <em>required</em> CSS functionality is not supported with this implementation model. Additionally, inline styles can be difficult to override, which makes components that use them historically harder to extend.</p>\n<p>You can certainly go this route, and several libraries exist to allow for this implementation while adding some of these needed features back, of particular note is <a href="https://github.com/FormidableLabs/radium">Radium</a>.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="is not"\n title=""\n src="/interpreter/static/33-is-not-78258f166929d11641c453cd30f0342a-83a8b.png"\n srcset="/interpreter/static/33-is-not-78258f166929d11641c453cd30f0342a-8992e.png 163w,\n/interpreter/static/33-is-not-78258f166929d11641c453cd30f0342a-ae0a7.png 325w,\n/interpreter/static/33-is-not-78258f166929d11641c453cd30f0342a-83a8b.png 650w,\n/interpreter/static/33-is-not-78258f166929d11641c453cd30f0342a-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>This is an example of an inline style, and one of the first methods advocated for CSS in JS.</p>\n<p>This is <em>not</em> what I’d consider the best way to write CSS in JS, although it does have its place (particularly if props change very regularly, or in other instances when performance may suffer with rapid changes).</p>\n<p>As noted, you lose out entirely on some of the best parts of CSS, so this doesn’t seem, to me, to be the best implementation of CSS in JS, or the one to reach for most readily.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="inline styles"\n title=""\n src="/interpreter/static/34-inline-styles-821e9a64959793e04b1684f2b3fff8d8-83a8b.png"\n srcset="/interpreter/static/34-inline-styles-821e9a64959793e04b1684f2b3fff8d8-8992e.png 163w,\n/interpreter/static/34-inline-styles-821e9a64959793e04b1684f2b3fff8d8-ae0a7.png 325w,\n/interpreter/static/34-inline-styles-821e9a64959793e04b1684f2b3fff8d8-83a8b.png 650w,\n/interpreter/static/34-inline-styles-821e9a64959793e04b1684f2b3fff8d8-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>It’s high time to begin talking about what CSS in JS actually <em>is</em>. We’ll go over some high level goals of CSS in JS, as well as some common patterns and coding techniques for what it can do for a modern application.</p>\n<p>Additionally, detail will be provided for how it actually solves the aforementioned “problems with CSS”.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="is"\n title=""\n src="/interpreter/static/35-is-76bc4f37feb628ee58f63f3baead9f18-83a8b.png"\n srcset="/interpreter/static/35-is-76bc4f37feb628ee58f63f3baead9f18-8992e.png 163w,\n/interpreter/static/35-is-76bc4f37feb628ee58f63f3baead9f18-ae0a7.png 325w,\n/interpreter/static/35-is-76bc4f37feb628ee58f63f3baead9f18-83a8b.png 650w,\n/interpreter/static/35-is-76bc4f37feb628ee58f63f3baead9f18-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>CSS abstracts style to the document level.</p>\n<p>CSS in JS abstracts style to the component level.</p>\n<p>In a similar way that React, Vue, Angular, et al. are abstractions on JavaScript, CSS in JS abstracts upon the base model of CSS and fixes some of its inherent issues!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="abstractions"\n title=""\n src="/interpreter/static/36-abstractions-e1b82cc34970af4ee11349f29e1a5c45-83a8b.png"\n srcset="/interpreter/static/36-abstractions-e1b82cc34970af4ee11349f29e1a5c45-8992e.png 163w,\n/interpreter/static/36-abstractions-e1b82cc34970af4ee11349f29e1a5c45-ae0a7.png 325w,\n/interpreter/static/36-abstractions-e1b82cc34970af4ee11349f29e1a5c45-83a8b.png 650w,\n/interpreter/static/36-abstractions-e1b82cc34970af4ee11349f29e1a5c45-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>With naming methodologies like BEM, we can get pseudo encapsulation. With Shadow DOM, we can get true encapsulation at the component level, but this requires a polyfill in many browsers and isn’t quite at a point where it’s the perfect solution for any application.</p>\n<p>With CSS in JS, we can get true encapsulation at the component level, today. Under the hood, a unique hash will be generated for the class name, and a real stylesheet will be created with this class. This allows us to target a unique element (a component!) today, without polyfills and in an automated way so we never again need to waste cognitive cycles constructing meaningful, isolated class names.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="scoped styles"\n title=""\n src="/interpreter/static/37-scoped-styles-d8568b580e63e52ea959d69c93aef929-83a8b.png"\n srcset="/interpreter/static/37-scoped-styles-d8568b580e63e52ea959d69c93aef929-8992e.png 163w,\n/interpreter/static/37-scoped-styles-d8568b580e63e52ea959d69c93aef929-ae0a7.png 325w,\n/interpreter/static/37-scoped-styles-d8568b580e63e52ea959d69c93aef929-83a8b.png 650w,\n/interpreter/static/37-scoped-styles-d8568b580e63e52ea959d69c93aef929-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Leveraging the full power of JavaScript lets us extend CSS in new, interesting ways. We can create a “mixin” just like we can in SASS, LESS, etc. We can use helpers to lighten a color, darken a color, share style code, etc. We can, of course, easily share constants and modify them, as needed. We can do all of us in a language each of us are familiar with (JavaScript!), and without learning/remembering syntax for doing so in SASS, LESS, etc.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="powerful"\n title=""\n src="/interpreter/static/38-powerful-4e8acac3f61bdfdd13defddfc5d83442-83a8b.png"\n srcset="/interpreter/static/38-powerful-4e8acac3f61bdfdd13defddfc5d83442-8992e.png 163w,\n/interpreter/static/38-powerful-4e8acac3f61bdfdd13defddfc5d83442-ae0a7.png 325w,\n/interpreter/static/38-powerful-4e8acac3f61bdfdd13defddfc5d83442-83a8b.png 650w,\n/interpreter/static/38-powerful-4e8acac3f61bdfdd13defddfc5d83442-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>A real stylesheet gives you the best parts of CSS (media queries, pseudo styles, flexbox, etc.).</p>\n<p>It lessens the bad parts of CSS (globals!) by scoping to a class name</p>\n<p>If you already know CSS, great! CSS in JS presumes that you do; the properties, rules, etc. of CSS that you already know and love continue to function just as they do in vanilla CSS.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="real styles"\n title=""\n src="/interpreter/static/39-real-styles-a4451a88b5301e8c08d9efa5929d7f49-83a8b.png"\n srcset="/interpreter/static/39-real-styles-a4451a88b5301e8c08d9efa5929d7f49-8992e.png 163w,\n/interpreter/static/39-real-styles-a4451a88b5301e8c08d9efa5929d7f49-ae0a7.png 325w,\n/interpreter/static/39-real-styles-a4451a88b5301e8c08d9efa5929d7f49-83a8b.png 650w,\n/interpreter/static/39-real-styles-a4451a88b5301e8c08d9efa5929d7f49-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>As an example, here is how styled-components (a library we will soon talk about) constructs a real style sheet. A template string is passed to the library containing the CSS styles. From these styles, a unique hash for a class name is created, and applied to a style tag in the head tags of your application. This constructed class name is automatically applied to your component!</p>\n<p>It’s an automated process to a previously manual problem, and you get the benefit of writing <em>real</em> CSS!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="real styles-example"\n title=""\n src="/interpreter/static/40-real-styles-example-5a0d73b416bf52c4d1120e609d6150ba-83a8b.png"\n srcset="/interpreter/static/40-real-styles-example-5a0d73b416bf52c4d1120e609d6150ba-8992e.png 163w,\n/interpreter/static/40-real-styles-example-5a0d73b416bf52c4d1120e609d6150ba-ae0a7.png 325w,\n/interpreter/static/40-real-styles-example-5a0d73b416bf52c4d1120e609d6150ba-83a8b.png 650w,\n/interpreter/static/40-real-styles-example-5a0d73b416bf52c4d1120e609d6150ba-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>CSS in JS brings CSS into the component era.</p>\n<p>We’ve removed globals from our JavaScript, why should we not do the same with our CSS?</p>\n<p>We’ve established the component model for our JavaScript, why not bring CSS into the fold and enhance upon this model?</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="component styling"\n title=""\n src="/interpreter/static/41-component-styling-8692895783772a30e0390d51b0c99f99-83a8b.png"\n srcset="/interpreter/static/41-component-styling-8692895783772a30e0390d51b0c99f99-8992e.png 163w,\n/interpreter/static/41-component-styling-8692895783772a30e0390d51b0c99f99-ae0a7.png 325w,\n/interpreter/static/41-component-styling-8692895783772a30e0390d51b0c99f99-83a8b.png 650w,\n/interpreter/static/41-component-styling-8692895783772a30e0390d51b0c99f99-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Using JavaScript to write styles feels incredibly natural and intuitive, especially when considering the previous arguments we’ve made concerning sharing of constants, using JavaScript functions as mixins, etc.</p>\n<p><em>Additionally</em>, we are creating distributable, single import components that are entirely encapsulated. No configuring of loaders, no loading of additional stylesheets. One import, highly shareable, highly consumable, and highly simple!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="java script-styling"\n title=""\n src="/interpreter/static/42-java-script-styling-30988cb19901d846b065e67c25e55eaa-83a8b.png"\n srcset="/interpreter/static/42-java-script-styling-30988cb19901d846b065e67c25e55eaa-8992e.png 163w,\n/interpreter/static/42-java-script-styling-30988cb19901d846b065e67c25e55eaa-ae0a7.png 325w,\n/interpreter/static/42-java-script-styling-30988cb19901d846b065e67c25e55eaa-83a8b.png 650w,\n/interpreter/static/42-java-script-styling-30988cb19901d846b065e67c25e55eaa-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>CSS in JS gives us truly unlimited semantic elements.</p>\n<p>HTML5 gave us <code>header</code>, <code>footer</code>, <code>section</code>, <code>aside</code>, and others.</p>\n<p>CSS in JS gives us truly unlimited semantic elements that are semantically clear at a glance: <code>Logo</code>, <code>Branding</code>, <code>Toolbar</code>, <code>Copyright</code>, the possibilities are endless.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="semantic elements"\n title=""\n src="/interpreter/static/43-semantic-elements-3f5bf969151e06e2669ade791254e03e-83a8b.png"\n srcset="/interpreter/static/43-semantic-elements-3f5bf969151e06e2669ade791254e03e-8992e.png 163w,\n/interpreter/static/43-semantic-elements-3f5bf969151e06e2669ade791254e03e-ae0a7.png 325w,\n/interpreter/static/43-semantic-elements-3f5bf969151e06e2669ade791254e03e-83a8b.png 650w,\n/interpreter/static/43-semantic-elements-3f5bf969151e06e2669ade791254e03e-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>At a glance, each element’s intent & purpose is incredibly clear. On the left, <em>some</em> of the element’s meaning is clear. It’s clear that semantic elements have meaningful value, and the fact that CSS in JS gives effectively unlimited semantic elements is an underappreciated win!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="semantic comparison"\n title=""\n src="/interpreter/static/44-semantic-comparison-40e6d6c7710f74a6f3893c5542da204d-83a8b.png"\n srcset="/interpreter/static/44-semantic-comparison-40e6d6c7710f74a6f3893c5542da204d-8992e.png 163w,\n/interpreter/static/44-semantic-comparison-40e6d6c7710f74a6f3893c5542da204d-ae0a7.png 325w,\n/interpreter/static/44-semantic-comparison-40e6d6c7710f74a6f3893c5542da204d-83a8b.png 650w,\n/interpreter/static/44-semantic-comparison-40e6d6c7710f74a6f3893c5542da204d-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The left is the mental model we must keep in our minds when writing CSS centered around HTML. We must be aware that a class we apply in HTML is styled with a class name. We must be aware that these class names can cascade and stack, sometimes interfering in unforseen ways. These cacading rules then become stylesheets in our DOM that can themselves conflict.</p>\n<p>The right is the mental model when writing CSS in JS. Write HTML (JSX) that is encapsulated with component-scoped styles. No stacking. Never worry again about CSS rule specificity (and no <code>!important</code> hacks), and truly think in components!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="style cognitive-load"\n title=""\n src="/interpreter/static/45-style-cognitive-load-5a12c703bfbe7706a1188dea833d88fd-83a8b.png"\n srcset="/interpreter/static/45-style-cognitive-load-5a12c703bfbe7706a1188dea833d88fd-8992e.png 163w,\n/interpreter/static/45-style-cognitive-load-5a12c703bfbe7706a1188dea833d88fd-ae0a7.png 325w,\n/interpreter/static/45-style-cognitive-load-5a12c703bfbe7706a1188dea833d88fd-83a8b.png 650w,\n/interpreter/static/45-style-cognitive-load-5a12c703bfbe7706a1188dea833d88fd-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The case for CSS in JS has hopefully been made apparent. These techniques solve real problems of CSS. But, how do they solve them? What libraries exist to implement these CSS in JS techniques, and what does writing code in each of them look like?</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="libraries intro"\n title=""\n src="/interpreter/static/46-libraries-intro-7dbb0e8a59141dfb98f7009d8fa2c311-83a8b.png"\n srcset="/interpreter/static/46-libraries-intro-7dbb0e8a59141dfb98f7009d8fa2c311-8992e.png 163w,\n/interpreter/static/46-libraries-intro-7dbb0e8a59141dfb98f7009d8fa2c311-ae0a7.png 325w,\n/interpreter/static/46-libraries-intro-7dbb0e8a59141dfb98f7009d8fa2c311-83a8b.png 650w,\n/interpreter/static/46-libraries-intro-7dbb0e8a59141dfb98f7009d8fa2c311-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>First, a caveat: most of these libraries are tied to React. However, not <em>all</em> of them are tied to React, and I’ll specifically point out libraries that do not require React.</p>\n<p>In general, libraries that simply export a className hash (which can be used as a <code>className</code> in the consuming component) are typically framework agnostic. Some of the most interesting libraries expose several libraries, some of which can be used in any framework, and others that specifically target React.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="caveat"\n title=""\n src="/interpreter/static/47-caveat-01eefdff70857264c7de7cd2ad7b5604-83a8b.png"\n srcset="/interpreter/static/47-caveat-01eefdff70857264c7de7cd2ad7b5604-8992e.png 163w,\n/interpreter/static/47-caveat-01eefdff70857264c7de7cd2ad7b5604-ae0a7.png 325w,\n/interpreter/static/47-caveat-01eefdff70857264c7de7cd2ad7b5604-83a8b.png 650w,\n/interpreter/static/47-caveat-01eefdff70857264c7de7cd2ad7b5604-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>styled-components is what I would call the “gateway drug” to CSS in JS libraries. You author using template strings, so you can write CSS not as an object, but as a string and dasherized just like it’s authored in CSS.</p>\n<p>This means that styled-components is probably the easiest to get up and running, and I would recommend it to get your feet wet with CSS in JS techniques. In addition, it’s a great choice for beginning to move off of a formerly vanilla CSS code base, because you can generally re-use most of your existing CSS, with some small modifications here and there.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="styled components"\n title=""\n src="/interpreter/static/48-styled-components-c2c599d50e53d903f245aae8cc039c62-83a8b.png"\n srcset="/interpreter/static/48-styled-components-c2c599d50e53d903f245aae8cc039c62-8992e.png 163w,\n/interpreter/static/48-styled-components-c2c599d50e53d903f245aae8cc039c62-ae0a7.png 325w,\n/interpreter/static/48-styled-components-c2c599d50e53d903f245aae8cc039c62-83a8b.png 650w,\n/interpreter/static/48-styled-components-c2c599d50e53d903f245aae8cc039c62-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The css helper constructs a “mixin” that can be re-used and applied when needed. This can be particularly helpful to encapsulate rules, and then use them conditionally, when required.</p>\n<p>Additionally, you can see here another of styled-components’ great features. Prop injection! This means that props can be passed to these styled components, and then parsed and style rules can be conditionally applied/removed. Very cool!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="styled components-example"\n title=""\n src="/interpreter/static/49-styled-components-example-59b7638d205ca64217a0f641fbdc9585-83a8b.png"\n srcset="/interpreter/static/49-styled-components-example-59b7638d205ca64217a0f641fbdc9585-8992e.png 163w,\n/interpreter/static/49-styled-components-example-59b7638d205ca64217a0f641fbdc9585-ae0a7.png 325w,\n/interpreter/static/49-styled-components-example-59b7638d205ca64217a0f641fbdc9585-83a8b.png 650w,\n/interpreter/static/49-styled-components-example-59b7638d205ca64217a0f641fbdc9585-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Glamorous built on some of the ideas of not only styled-components, but also glamor, the library that powers much of Glamorous’ underlying functionality.</p>\n<p>The central difference with Glamorous is that is expects objects (similar to the kind passed to inline styles), but that can also be merged with subsequent objects <em>and</em> that can also accept things like media queries, pseudo styles, etc.</p>\n<p>It might seem more natural to begin using styled-components, but as of late, I’ve found myself increasingly drawn to and really liking the functionality available in Glamorous, particularly with the style objects. Merging, conditional applying of rules, etc. feel very natural with Glamorous.</p>\n<p><em>Note: glamor, the underlying library, is framework agnostic!</em></p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="glamorous"\n title=""\n src="/interpreter/static/50-glamorous-2e3b3dd3d895fd97f60f0ec952984e23-83a8b.png"\n srcset="/interpreter/static/50-glamorous-2e3b3dd3d895fd97f60f0ec952984e23-8992e.png 163w,\n/interpreter/static/50-glamorous-2e3b3dd3d895fd97f60f0ec952984e23-ae0a7.png 325w,\n/interpreter/static/50-glamorous-2e3b3dd3d895fd97f60f0ec952984e23-83a8b.png 650w,\n/interpreter/static/50-glamorous-2e3b3dd3d895fd97f60f0ec952984e23-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>We can begin to get a solid feel for Glamorous’ API. The function takes 0 to n objects (or functions that return an object). Any function is injected with the current props passed to the component, as well as a global theme prop if tying into Glamorous’ exposed theming capability.</p>\n<p>The code here is using the object rest spread syntax, which makes the code slightly more terse.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="glamorous example"\n title=""\n src="/interpreter/static/51-glamorous-example-61655a75222e7dffbefd0e9ef4fb8953-83a8b.png"\n srcset="/interpreter/static/51-glamorous-example-61655a75222e7dffbefd0e9ef4fb8953-8992e.png 163w,\n/interpreter/static/51-glamorous-example-61655a75222e7dffbefd0e9ef4fb8953-ae0a7.png 325w,\n/interpreter/static/51-glamorous-example-61655a75222e7dffbefd0e9ef4fb8953-83a8b.png 650w,\n/interpreter/static/51-glamorous-example-61655a75222e7dffbefd0e9ef4fb8953-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Emotion is another excellent library that feels very similar to styled-components because it also allows for template literals to inject styles. The key difference, and a particularly interesting idea, is that it ships with a babel plugin which attempts to pre-compile the styles that aren’t dynamic, thereby reducing the payload of the resulting bundle.</p>\n<p>In general, I think the ideas of minimizing (or removing entirely!) a runtime are particularly interesting, and will remain an area to keep an eye on as the community matures and develops further processes and tooling.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="emotion"\n title=""\n src="/interpreter/static/52-emotion-6be1ebaaafa157b649360350337a269a-83a8b.png"\n srcset="/interpreter/static/52-emotion-6be1ebaaafa157b649360350337a269a-8992e.png 163w,\n/interpreter/static/52-emotion-6be1ebaaafa157b649360350337a269a-ae0a7.png 325w,\n/interpreter/static/52-emotion-6be1ebaaafa157b649360350337a269a-83a8b.png 650w,\n/interpreter/static/52-emotion-6be1ebaaafa157b649360350337a269a-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>As you can see, the code feels <em>very</em> similar to styled-components. If you’re looking for a similar API but with some other benefits (and trade-offs), consider emotion as it’s a very solid alternative.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="emotion example"\n title=""\n src="/interpreter/static/53-emotion-example-03214a7dd2b7616aad3d774c4e850ecc-83a8b.png"\n srcset="/interpreter/static/53-emotion-example-03214a7dd2b7616aad3d774c4e850ecc-8992e.png 163w,\n/interpreter/static/53-emotion-example-03214a7dd2b7616aad3d774c4e850ecc-ae0a7.png 325w,\n/interpreter/static/53-emotion-example-03214a7dd2b7616aad3d774c4e850ecc-83a8b.png 650w,\n/interpreter/static/53-emotion-example-03214a7dd2b7616aad3d774c4e850ecc-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Polished is a <em>framework agnostic</em> collection of utility methods for CSS in JS functionality. Some have described it as the “lodash of CSS in JS,” and that’s a very fair comparison.</p>\n<p>Many helpers/mixins are provided for usage in any CSS in JS library, and functionality such as <code>lighten</code>, <code>darken</code>, <code>rgba</code>, etc. can be utilized in your application to do some really useful things.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="polished"\n title=""\n src="/interpreter/static/54-polished-cd279f2abf3c2e6227429e47ced60feb-83a8b.png"\n srcset="/interpreter/static/54-polished-cd279f2abf3c2e6227429e47ced60feb-8992e.png 163w,\n/interpreter/static/54-polished-cd279f2abf3c2e6227429e47ced60feb-ae0a7.png 325w,\n/interpreter/static/54-polished-cd279f2abf3c2e6227429e47ced60feb-83a8b.png 650w,\n/interpreter/static/54-polished-cd279f2abf3c2e6227429e47ced60feb-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Polished is particularly useful in adjusting color (hue shifting, adjusting transpraency, darkening colors, lightening colors, etc.), but contains a number of other additional utilities.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="polished example"\n title=""\n src="/interpreter/static/55-polished-example-d29cdc87766ad646e96e1647ddb8cda7-83a8b.png"\n srcset="/interpreter/static/55-polished-example-d29cdc87766ad646e96e1647ddb8cda7-8992e.png 163w,\n/interpreter/static/55-polished-example-d29cdc87766ad646e96e1647ddb8cda7-ae0a7.png 325w,\n/interpreter/static/55-polished-example-d29cdc87766ad646e96e1647ddb8cda7-83a8b.png 650w,\n/interpreter/static/55-polished-example-d29cdc87766ad646e96e1647ddb8cda7-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>These are just the color methods, but polished contains a bunch more including:</p>\n<ul>\n<li>\n<p>em/rem helpers</p>\n</li>\n<li>\n<p>radial gradient generators</p>\n</li>\n<li>\n<p>normalize.css injection (CSS reset)</p>\n</li>\n<li>\n<p>shorthands for common things such as text-overflow ellipsis, font-face, etc.</p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="polished methods"\n title=""\n src="/interpreter/static/56-polished-methods-41e970c0352d4df07ac5322edcad1525-83a8b.png"\n srcset="/interpreter/static/56-polished-methods-41e970c0352d4df07ac5322edcad1525-8992e.png 163w,\n/interpreter/static/56-polished-methods-41e970c0352d4df07ac5322edcad1525-ae0a7.png 325w,\n/interpreter/static/56-polished-methods-41e970c0352d4df07ac5322edcad1525-83a8b.png 650w,\n/interpreter/static/56-polished-methods-41e970c0352d4df07ac5322edcad1525-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>If I had more time, I’d love to cover <em>every</em> major library that can be used. Unfortunately, in the interest of time, I’m only able to cover a few. That said, there are <em>so</em> many libraries in the frontend ecosystem that can be utilized.</p>\n<p>Also note that every single one of these libraries is framework agnostic!</p>\n<ul>\n<li>\n<p><a href="https://github.com/cssinjs/jss">JSS</a></p>\n</li>\n<li>\n<p><a href="https://github.com/callstack/linaria">linaria</a></p>\n</li>\n<li>\n<p><a href="https://github.com/rtsao/styletron">styletron</a></p>\n</li>\n<li>\n<p><a href="https://github.com/rofrischmann/fela">fela</a></p>\n</li>\n<li>\n<p><a href="https://github.com/Khan/aphrodite">aphrodite</a></p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="other libraries"\n title=""\n src="/interpreter/static/57-other-libraries-7acd62a1b65cb8954a9c79ec2dd7d27c-83a8b.png"\n srcset="/interpreter/static/57-other-libraries-7acd62a1b65cb8954a9c79ec2dd7d27c-8992e.png 163w,\n/interpreter/static/57-other-libraries-7acd62a1b65cb8954a9c79ec2dd7d27c-ae0a7.png 325w,\n/interpreter/static/57-other-libraries-7acd62a1b65cb8954a9c79ec2dd7d27c-83a8b.png 650w,\n/interpreter/static/57-other-libraries-7acd62a1b65cb8954a9c79ec2dd7d27c-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>It <em>can</em> be helpful to consider library downlaod count, but that is in no way, shape, or form indicative of a library’s quality or usefulness for your application.</p>\n<p>That said, it can be valuable just to get a baseline of relative support, community activity, etc. which can be a metric to consider when targeting a CSS in JS library to use in your application. </p>\n<ul>\n<li>\n<p>styled-components and glamorous are two of the most popular and “hot” choices</p>\n</li>\n<li>\n<p>glamorous requires glamor, so a lot of the glamor downloads are likely from glamorous (but note: glamor can be used outside of glamorous)</p>\n</li>\n<li>\n<p>aphrodite and radium were huge players (and may still be a good choice in certain scenarios), but I tend to like the others a bit more</p>\n</li>\n<li>\n<p>radium is inline style based, but adds pseudo styles and other expected CSS functionality while still using inline styles; however, it’s not quite as utilized or “in vogue” as it may have once been</p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="library download-count"\n title=""\n src="/interpreter/static/58-library-download-count-0c7c0f18489ca0831d5c29680e14a1d7-83a8b.png"\n srcset="/interpreter/static/58-library-download-count-0c7c0f18489ca0831d5c29680e14a1d7-8992e.png 163w,\n/interpreter/static/58-library-download-count-0c7c0f18489ca0831d5c29680e14a1d7-ae0a7.png 325w,\n/interpreter/static/58-library-download-count-0c7c0f18489ca0831d5c29680e14a1d7-83a8b.png 650w,\n/interpreter/static/58-library-download-count-0c7c0f18489ca0831d5c29680e14a1d7-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Similar story here, styled-components and glamorous are on the rise, while the others are relatively constant.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="github stars-count"\n title=""\n src="/interpreter/static/59-github-stars-count-769c96960559f2692c69f943695cc217-83a8b.png"\n srcset="/interpreter/static/59-github-stars-count-769c96960559f2692c69f943695cc217-8992e.png 163w,\n/interpreter/static/59-github-stars-count-769c96960559f2692c69f943695cc217-ae0a7.png 325w,\n/interpreter/static/59-github-stars-count-769c96960559f2692c69f943695cc217-83a8b.png 650w,\n/interpreter/static/59-github-stars-count-769c96960559f2692c69f943695cc217-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The cost of using these libraries is non-null, even when using babel plugins or other techniques to reduce the file size as much as possible.</p>\n<p>However, the cost is relatively small, so weighing developer utility and other benefits of CSS in JS vs. a relatively small size seems to be a fairly inoccuous concern.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="payload size-chart"\n title=""\n src="/interpreter/static/60-payload-size-chart-492dddd6a853446b289155af391633b1-83a8b.png"\n srcset="/interpreter/static/60-payload-size-chart-492dddd6a853446b289155af391633b1-8992e.png 163w,\n/interpreter/static/60-payload-size-chart-492dddd6a853446b289155af391633b1-ae0a7.png 325w,\n/interpreter/static/60-payload-size-chart-492dddd6a853446b289155af391633b1-83a8b.png 650w,\n/interpreter/static/60-payload-size-chart-492dddd6a853446b289155af391633b1-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Seeing some of the companies that are utilizing these technologies lends some validity to the practice and makes it more obvious that there’s some real value being generated by the usage of these libraries.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="companies"\n title=""\n src="/interpreter/static/61-companies-1ab700487aecc1403336f6348dd190c9-83a8b.png"\n srcset="/interpreter/static/61-companies-1ab700487aecc1403336f6348dd190c9-8992e.png 163w,\n/interpreter/static/61-companies-1ab700487aecc1403336f6348dd190c9-ae0a7.png 325w,\n/interpreter/static/61-companies-1ab700487aecc1403336f6348dd190c9-83a8b.png 650w,\n/interpreter/static/61-companies-1ab700487aecc1403336f6348dd190c9-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>I think it’s important to actually show some real-world usage and common patterns for writing “real world” code in each of these libraries.</p>\n<p>Common things like theming, utilizing props, inheriting/composing styles, etc.</p>\n<p><em>Note: I’m not endorsing any particular library, so I’ll jump around a bit to give you a better idea of what each library feels like.</em></p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="usage"\n title=""\n src="/interpreter/static/62-usage-2b88e3136e80cd432818e1b30c3c929e-83a8b.png"\n srcset="/interpreter/static/62-usage-2b88e3136e80cd432818e1b30c3c929e-8992e.png 163w,\n/interpreter/static/62-usage-2b88e3136e80cd432818e1b30c3c929e-ae0a7.png 325w,\n/interpreter/static/62-usage-2b88e3136e80cd432818e1b30c3c929e-83a8b.png 650w,\n/interpreter/static/62-usage-2b88e3136e80cd432818e1b30c3c929e-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Props injection is a natural, React-y method of altering a given component’s style under certain conditions. For instance, if we were to re-visit our earlier CSS only button, we can create the same with props, but with complete encapsulation to that single button component.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="using props"\n title=""\n src="/interpreter/static/63-using-props-337f911300da8a40bc16592e9a44e2d8-83a8b.png"\n srcset="/interpreter/static/63-using-props-337f911300da8a40bc16592e9a44e2d8-8992e.png 163w,\n/interpreter/static/63-using-props-337f911300da8a40bc16592e9a44e2d8-ae0a7.png 325w,\n/interpreter/static/63-using-props-337f911300da8a40bc16592e9a44e2d8-83a8b.png 650w,\n/interpreter/static/63-using-props-337f911300da8a40bc16592e9a44e2d8-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>A common question is that one of CSS’ great features is inheritance and easy extension of base classes. Inheritance is typically accomplished in these libraries by injecting a previously styled component (😉) and adding additional styles, as needed. All previously defined styles will be merged with, or possibly replaced by, the new styles.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="inheritance"\n title=""\n src="/interpreter/static/64-inheritance-5fee39d4a3de8381bad6a8f061d3888b-83a8b.png"\n srcset="/interpreter/static/64-inheritance-5fee39d4a3de8381bad6a8f061d3888b-8992e.png 163w,\n/interpreter/static/64-inheritance-5fee39d4a3de8381bad6a8f061d3888b-ae0a7.png 325w,\n/interpreter/static/64-inheritance-5fee39d4a3de8381bad6a8f061d3888b-83a8b.png 650w,\n/interpreter/static/64-inheritance-5fee39d4a3de8381bad6a8f061d3888b-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>One final reminder that in each of these libraries, real CSS and real stylesheets are added to the DOM. The value of CSS remains but with the clear and numerous benefits that CSS in JS provides.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="real css"\n title=""\n src="/interpreter/static/65-real-css-4ee04c27e4380b693a26f523d129f2e0-83a8b.png"\n srcset="/interpreter/static/65-real-css-4ee04c27e4380b693a26f523d129f2e0-8992e.png 163w,\n/interpreter/static/65-real-css-4ee04c27e4380b693a26f523d129f2e0-ae0a7.png 325w,\n/interpreter/static/65-real-css-4ee04c27e4380b693a26f523d129f2e0-83a8b.png 650w,\n/interpreter/static/65-real-css-4ee04c27e4380b693a26f523d129f2e0-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>But what about animations? Those inherently require a global animation name!</p>\n<p>Most libraries include some type of helper utility to return a unique identifier/hash for those animations so that globals remain stripped from the code base.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="animation"\n title=""\n src="/interpreter/static/66-animation-7f3eeeb8bc85df81c07c49522fdeb95e-83a8b.png"\n srcset="/interpreter/static/66-animation-7f3eeeb8bc85df81c07c49522fdeb95e-8992e.png 163w,\n/interpreter/static/66-animation-7f3eeeb8bc85df81c07c49522fdeb95e-ae0a7.png 325w,\n/interpreter/static/66-animation-7f3eeeb8bc85df81c07c49522fdeb95e-83a8b.png 650w,\n/interpreter/static/66-animation-7f3eeeb8bc85df81c07c49522fdeb95e-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>If you’re designing a component library and want to make it CSS in JS friendly, consider exposing the className prop for consumption.</p>\n<ul>\n<li>\n<p>Most libraries inject a className—or provide a className—which would then be applied on top of the existing styles</p>\n</li>\n<li>\n<p>Additionally, if you are “wrapping” your styled elements, this is a great way to make those wrappers extensible, as well</p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="using class-name"\n title=""\n src="/interpreter/static/67-using-class-name-09000e9042dad103eecbe5add994d1ee-83a8b.png"\n srcset="/interpreter/static/67-using-class-name-09000e9042dad103eecbe5add994d1ee-8992e.png 163w,\n/interpreter/static/67-using-class-name-09000e9042dad103eecbe5add994d1ee-ae0a7.png 325w,\n/interpreter/static/67-using-class-name-09000e9042dad103eecbe5add994d1ee-83a8b.png 650w,\n/interpreter/static/67-using-class-name-09000e9042dad103eecbe5add994d1ee-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Libraries that require a certain class structure (e.g. Bootstrap), can also work with CSS in JS libraries!</p>\n<p>This example exposes a wrapped bootstrap Alert, which can then be used as a regular React component with a prop specifying the type of alert (e.g. <code>success</code>, <code>info</code>, etc.)</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="external libraries"\n title=""\n src="/interpreter/static/68-external-libraries-a9f5e99942fa34088b913d4c5bed84ae-83a8b.png"\n srcset="/interpreter/static/68-external-libraries-a9f5e99942fa34088b913d4c5bed84ae-8992e.png 163w,\n/interpreter/static/68-external-libraries-a9f5e99942fa34088b913d4c5bed84ae-ae0a7.png 325w,\n/interpreter/static/68-external-libraries-a9f5e99942fa34088b913d4c5bed84ae-83a8b.png 650w,\n/interpreter/static/68-external-libraries-a9f5e99942fa34088b913d4c5bed84ae-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p><em>Some</em> of the time, it may be necessary to inject globals, in particular when targeting <code>html</code>, <code>body</code>, etc.</p>\n<p>For these times, most libraries include a mechanism to inject a global into a DOM style tag.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="injecting globals"\n title=""\n src="/interpreter/static/69-injecting-globals-716c3dcc90bcaf20d4c5f0a25725400b-83a8b.png"\n srcset="/interpreter/static/69-injecting-globals-716c3dcc90bcaf20d4c5f0a25725400b-8992e.png 163w,\n/interpreter/static/69-injecting-globals-716c3dcc90bcaf20d4c5f0a25725400b-ae0a7.png 325w,\n/interpreter/static/69-injecting-globals-716c3dcc90bcaf20d4c5f0a25725400b-83a8b.png 650w,\n/interpreter/static/69-injecting-globals-716c3dcc90bcaf20d4c5f0a25725400b-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Nesting <em>is</em> supported in most of these libraries, but it can be seen as a kind of anti-pattern in certain circumstances, <em>especially</em> if you’re targeting a child selector.</p>\n<p>However, that said, <a href="https://www.styled-components.com/docs/faqs">styled-components documentation</a> mentions that:</p>\n<blockquote>\n<p>… Used sparingly it’s a great way to lighten your code by reducing the need to create explicit classes for every element.</p>\n</blockquote>\n<p>So use with caution, but it can be a decent technique to lighten some of your component’s styles!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="nesting"\n title=""\n src="/interpreter/static/70-nesting-a6f843804c70c2641503de0c2704592b-83a8b.png"\n srcset="/interpreter/static/70-nesting-a6f843804c70c2641503de0c2704592b-8992e.png 163w,\n/interpreter/static/70-nesting-a6f843804c70c2641503de0c2704592b-ae0a7.png 325w,\n/interpreter/static/70-nesting-a6f843804c70c2641503de0c2704592b-83a8b.png 650w,\n/interpreter/static/70-nesting-a6f843804c70c2641503de0c2704592b-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Theming is a particularly common use case that can be semi-difficult to architect cleanly. Most of these major libraries expose a <code>ThemeProvider</code> component which can be used to provide a theme (via context) to each styled component.</p>\n<p>It is, for instance, incredibly easy to make a light/dark theme for an application, or any number of color variants.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="theming intro"\n title=""\n src="/interpreter/static/71-theming-intro-1d05dfdfd08034dc8a92a7c7791cb178-83a8b.png"\n srcset="/interpreter/static/71-theming-intro-1d05dfdfd08034dc8a92a7c7791cb178-8992e.png 163w,\n/interpreter/static/71-theming-intro-1d05dfdfd08034dc8a92a7c7791cb178-ae0a7.png 325w,\n/interpreter/static/71-theming-intro-1d05dfdfd08034dc8a92a7c7791cb178-83a8b.png 650w,\n/interpreter/static/71-theming-intro-1d05dfdfd08034dc8a92a7c7791cb178-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Check out the <a href="https://css-in-js.dustinschau.com/#/theme-provider">code slide</a> to see the full, navigable example</p>\n<p>To actually add theming to an application, the process is <em>quite</em> simple:</p>\n<ul>\n<li>\n<p>Import the <code>ThemeProvider</code> component that most libs export</p>\n</li>\n<li>\n<p>Wrap your base component (e.g. App.js) in a <code>ThemeProvider</code></p>\n</li>\n<li>\n<p>Provide a <code>theme</code> prop to the <code>ThemeProvider</code></p>\n</li>\n<li>\n<p>All contained components will be injected via props/context with the current <code>theme</code></p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="theme provider"\n title=""\n src="/interpreter/static/72-theme-provider-a09e009a8f6962c8455ffe665b2aa1ab-83a8b.png"\n srcset="/interpreter/static/72-theme-provider-a09e009a8f6962c8455ffe665b2aa1ab-8992e.png 163w,\n/interpreter/static/72-theme-provider-a09e009a8f6962c8455ffe665b2aa1ab-ae0a7.png 325w,\n/interpreter/static/72-theme-provider-a09e009a8f6962c8455ffe665b2aa1ab-83a8b.png 650w,\n/interpreter/static/72-theme-provider-a09e009a8f6962c8455ffe665b2aa1ab-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>However, there aren’t any silver bullets it seems in frontend web technology. While CSS in JS may seem like a great fit for most applications, there are certainly some drawbacks that are worth considering.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="drawbacks intro"\n title=""\n src="/interpreter/static/73-drawbacks-intro-4c6f5162b32ffe049c5f9cda7fbb6efe-83a8b.png"\n srcset="/interpreter/static/73-drawbacks-intro-4c6f5162b32ffe049c5f9cda7fbb6efe-8992e.png 163w,\n/interpreter/static/73-drawbacks-intro-4c6f5162b32ffe049c5f9cda7fbb6efe-ae0a7.png 325w,\n/interpreter/static/73-drawbacks-intro-4c6f5162b32ffe049c5f9cda7fbb6efe-83a8b.png 650w,\n/interpreter/static/73-drawbacks-intro-4c6f5162b32ffe049c5f9cda7fbb6efe-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>When JavaScript is disabled (still can be a concern!), how do we progressively enhance? If JavaScript is our styling and rendering solution, we’re serving effectively an unstyled mess of content, which goes directly contrary to the ideas of progressive enhancement.</p>\n<p>0.2% of users may not seem like much, but if you’re Facebook scale or driving a lot of traffic it’s a concern</p>\n<ul>\n<li>1,000,000 monthly users means 2,000 users may not be getting a usable site</li>\n</ul>\n<p>How can we fix this?</p>\n<p>You can mitigate with server side rendering (something like next would be terrific) or statically rendering to HTML (with something like Gatsby)</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="java script-disabled"\n title=""\n src="/interpreter/static/74-java-script-disabled-9fd7eb851428e7dcfcf46eace5885e29-83a8b.png"\n srcset="/interpreter/static/74-java-script-disabled-9fd7eb851428e7dcfcf46eace5885e29-8992e.png 163w,\n/interpreter/static/74-java-script-disabled-9fd7eb851428e7dcfcf46eace5885e29-ae0a7.png 325w,\n/interpreter/static/74-java-script-disabled-9fd7eb851428e7dcfcf46eace5885e29-83a8b.png 650w,\n/interpreter/static/74-java-script-disabled-9fd7eb851428e7dcfcf46eace5885e29-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Rich Harris, creator of such tools as Rollup, Buble, Svelte, etc. raises an interesting point. Not only are the styles not scrapeable, but the styles can be hard to query, as well. Things like e2e tests or integration tests should not be pointed to a unique hash, and so it’s certainly a best practice to either use one of the existing babel plugins for most libraries that adds a humanized class name, or manually add your own!</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="not scrapeable"\n title=""\n src="/interpreter/static/75-not-scrapeable-6ccef834a60093da81ca5e918d8d60e9-83a8b.png"\n srcset="/interpreter/static/75-not-scrapeable-6ccef834a60093da81ca5e918d8d60e9-8992e.png 163w,\n/interpreter/static/75-not-scrapeable-6ccef834a60093da81ca5e918d8d60e9-ae0a7.png 325w,\n/interpreter/static/75-not-scrapeable-6ccef834a60093da81ca5e918d8d60e9-83a8b.png 650w,\n/interpreter/static/75-not-scrapeable-6ccef834a60093da81ca5e918d8d60e9-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Editor tooling is still in its infancy, but as CSS in JS continues to grow in popularity, I think we’ll see marked improvement on this front.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="editor tooling"\n title=""\n src="/interpreter/static/76-editor-tooling-bd072c657417ccb7cc9f925752d1315a-83a8b.png"\n srcset="/interpreter/static/76-editor-tooling-bd072c657417ccb7cc9f925752d1315a-8992e.png 163w,\n/interpreter/static/76-editor-tooling-bd072c657417ccb7cc9f925752d1315a-ae0a7.png 325w,\n/interpreter/static/76-editor-tooling-bd072c657417ccb7cc9f925752d1315a-83a8b.png 650w,\n/interpreter/static/76-editor-tooling-bd072c657417ccb7cc9f925752d1315a-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>It seems like every week there are new developments to get this working as seamlessly as possible. I believe this to be a space that will continue to see rapid improvements.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="editor tooling-plugin"\n title=""\n src="/interpreter/static/77-editor-tooling-plugin-ea9ace0cf992bd23b447cea05bed7491-83a8b.png"\n srcset="/interpreter/static/77-editor-tooling-plugin-ea9ace0cf992bd23b447cea05bed7491-8992e.png 163w,\n/interpreter/static/77-editor-tooling-plugin-ea9ace0cf992bd23b447cea05bed7491-ae0a7.png 325w,\n/interpreter/static/77-editor-tooling-plugin-ea9ace0cf992bd23b447cea05bed7491-83a8b.png 650w,\n/interpreter/static/77-editor-tooling-plugin-ea9ace0cf992bd23b447cea05bed7491-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>As with anything, if you’re directly injecting user input (even into CSS!) you open yourself up to issues</p>\n<p><em>Check out this <a href="https://reactarmory.com/answers/how-can-i-use-css-in-js-securely">great article</a> from React Armory</em></p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="sanitization concerns"\n title=""\n src="/interpreter/static/78-sanitization-concerns-fd65ea1c7477b6a6b8bdd3704366f708-83a8b.png"\n srcset="/interpreter/static/78-sanitization-concerns-fd65ea1c7477b6a6b8bdd3704366f708-8992e.png 163w,\n/interpreter/static/78-sanitization-concerns-fd65ea1c7477b6a6b8bdd3704366f708-ae0a7.png 325w,\n/interpreter/static/78-sanitization-concerns-fd65ea1c7477b6a6b8bdd3704366f708-83a8b.png 650w,\n/interpreter/static/78-sanitization-concerns-fd65ea1c7477b6a6b8bdd3704366f708-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Performance can be a concern, but I’d urge you here to not prematurely optimize. The difference between each of the libraries is arguably minimal, and the difference between CSS is relatively minimal as well.</p>\n<p>However, if you’re pushing Facebook-scale™, or after measuring your application’s performance, then it may be worth re-visiting whether these libraries are for you, or whether there are performance optimizations you can make to improve perf.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="performance concerns"\n title=""\n src="/interpreter/static/79-performance-concerns-ed0430cbd4b6e852a294d4705a933bee-83a8b.png"\n srcset="/interpreter/static/79-performance-concerns-ed0430cbd4b6e852a294d4705a933bee-8992e.png 163w,\n/interpreter/static/79-performance-concerns-ed0430cbd4b6e852a294d4705a933bee-ae0a7.png 325w,\n/interpreter/static/79-performance-concerns-ed0430cbd4b6e852a294d4705a933bee-83a8b.png 650w,\n/interpreter/static/79-performance-concerns-ed0430cbd4b6e852a294d4705a933bee-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>This benchmark measures the mount time of various CSS in JS libraries vs. inline styles (i.e. without a library).</p>\n<p>Any benchmark should be taken with a grain of salt. It is <em>incredibly</em> difficult to measure real-world performance, so most resort to doing large-scale operations (e.g. rendering a listview with thousands of rows, re-rendering a large table, etc.), which are generally not at all indicative of the type of application most are building.</p>\n<p>They can be helpful to get a general idea for performance, these are not necessarily what you’ll see in real world applications. </p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="performance chart-example"\n title=""\n src="/interpreter/static/80-performance-chart-example-826a0c53ce2fb661e34ab015087331e8-83a8b.png"\n srcset="/interpreter/static/80-performance-chart-example-826a0c53ce2fb661e34ab015087331e8-8992e.png 163w,\n/interpreter/static/80-performance-chart-example-826a0c53ce2fb661e34ab015087331e8-ae0a7.png 325w,\n/interpreter/static/80-performance-chart-example-826a0c53ce2fb661e34ab015087331e8-83a8b.png 650w,\n/interpreter/static/80-performance-chart-example-826a0c53ce2fb661e34ab015087331e8-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>So what should we make of all of this?</p>\n<ol>\n<li>CSS in JS solves very real problems of CSS</li>\n<li>It does so in a clean, component focused, and developer friendly way</li>\n<li>It abstracts the CSS model to the component level, rather than the document level</li>\n<li>It leverages the full power of JavaScript and the JavaScript ecosystem to <em>enhance</em> CSS</li>\n<li>…</li>\n<li>Profit</li>\n</ol>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="wrap up-intro"\n title=""\n src="/interpreter/static/81-wrap-up-intro-c21911631717782f6f0849afbb9324d7-83a8b.png"\n srcset="/interpreter/static/81-wrap-up-intro-c21911631717782f6f0849afbb9324d7-8992e.png 163w,\n/interpreter/static/81-wrap-up-intro-c21911631717782f6f0849afbb9324d7-ae0a7.png 325w,\n/interpreter/static/81-wrap-up-intro-c21911631717782f6f0849afbb9324d7-83a8b.png 650w,\n/interpreter/static/81-wrap-up-intro-c21911631717782f6f0849afbb9324d7-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>If I were to give a call to action, or best advice for getting started, I would give this:</p>\n<ol>\n<li>Start with <code>styled-components</code> as a starter (or final!) CSS in JS library</li>\n<li>It tends to be the most approachable as it uses actual CSS syntax, rather than style objects</li>\n<li>If you’re a fan, consider experimenting with other libraries in the ecosystem; who knows, you may like them even more than styled-components!</li>\n</ol>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="instructions"\n title=""\n src="/interpreter/static/82-instructions-2f9f08a9c9e5a42d59825090ccb2b3cd-83a8b.png"\n srcset="/interpreter/static/82-instructions-2f9f08a9c9e5a42d59825090ccb2b3cd-8992e.png 163w,\n/interpreter/static/82-instructions-2f9f08a9c9e5a42d59825090ccb2b3cd-ae0a7.png 325w,\n/interpreter/static/82-instructions-2f9f08a9c9e5a42d59825090ccb2b3cd-83a8b.png 650w,\n/interpreter/static/82-instructions-2f9f08a9c9e5a42d59825090ccb2b3cd-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>Overall, I’m <em>very</em> enthused with the direction that CSS in JS is taking and the things it’s doing for the ecosystem. I think it provides very tangible benefits to any application, particularly in the approach it takes to solve some of the problems of CSS <em>now,</em> and does so in a way that feels like a real improvement over authoring in CSS.</p>\n<p>If I were to start a new project right this moment, I’d author it using one of the CSS in JS libraries we’ve talked about, and I’d feel very enthused with that direction.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="happy"\n title=""\n src="/interpreter/static/83-happy-673f3998ab5c5059cb0c7266d74b748d-83a8b.png"\n srcset="/interpreter/static/83-happy-673f3998ab5c5059cb0c7266d74b748d-8992e.png 163w,\n/interpreter/static/83-happy-673f3998ab5c5059cb0c7266d74b748d-ae0a7.png 325w,\n/interpreter/static/83-happy-673f3998ab5c5059cb0c7266d74b748d-83a8b.png 650w,\n/interpreter/static/83-happy-673f3998ab5c5059cb0c7266d74b748d-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>The React community can certainly inspire what many have called “selection anxiety.” The proliferation of libraries, techniques, etc. can make it incredibly hard—especially as a beginner—to know what choice to make, and whether the choice is <em>most</em> correct.</p>\n<p>To help alleviate this, I recently created what I’m calling the “CSS in JS Playground,” which is a live-editable comparison of some of the most common CSS in JS libraries.</p>\n<p>My hope is that this tool will help each of you get a feel for each of the libraries, and hopefully empower you to make a more informed decision for what is best for <em>your</em> particular app and use cases.</p>\n<h2 id="features"><a href="#features" aria-hidden="true" class="anchor"><svg aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16"><path fill-rule="evenodd" d="M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z"></path></svg></a>Features</h2>\n<ul>\n<li>\n<p>Live editing and near instant preview of the code changes (using a web worker and the buble transpiler!)</p>\n</li>\n<li>\n<p>Service worker integration for better offline support</p>\n</li>\n<li>\n<p>A <em>rudimentary</em> file system! Add a file, and import it in the main index file!</p>\n</li>\n<li>\n<p>Persistence! Update any file (or add additional files) and you can share that URL with your friends</p>\n</li>\n<li>\n<p>Theming by way of a light/dark theme</p>\n</li>\n</ul>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="css in-js-playground"\n title=""\n src="/interpreter/static/84-css-in-js-playground-7591621d314becb55a3aca6e7c6682a7-83a8b.png"\n srcset="/interpreter/static/84-css-in-js-playground-7591621d314becb55a3aca6e7c6682a7-8992e.png 163w,\n/interpreter/static/84-css-in-js-playground-7591621d314becb55a3aca6e7c6682a7-ae0a7.png 325w,\n/interpreter/static/84-css-in-js-playground-7591621d314becb55a3aca6e7c6682a7-83a8b.png 650w,\n/interpreter/static/84-css-in-js-playground-7591621d314becb55a3aca6e7c6682a7-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>One of the best ways I’ve found to keep up with the latest technology updates, as well as just edify your currenet knowledge of common front-end (read: CSS in JS!) knowledge is to follow active community leaders on Twitter.</p>\n<p>Each of the people listed here are worth a follow, as they have some really interesting, great things to say and share about CSS in JS.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="people to-follow"\n title=""\n src="/interpreter/static/85-people-to-follow-f5049413db7909f68ea1c26c079ca60d-83a8b.png"\n srcset="/interpreter/static/85-people-to-follow-f5049413db7909f68ea1c26c079ca60d-8992e.png 163w,\n/interpreter/static/85-people-to-follow-f5049413db7909f68ea1c26c079ca60d-ae0a7.png 325w,\n/interpreter/static/85-people-to-follow-f5049413db7909f68ea1c26c079ca60d-83a8b.png 650w,\n/interpreter/static/85-people-to-follow-f5049413db7909f68ea1c26c079ca60d-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>This talk, and so many other things in the front-end community, would not be possible without the work of so many others. To them, I am so very grateful. Hopefully I, too, have contributed to the conversation!</p>\n<blockquote>\n<p>If I have seen further, it is by standing on the shoulders of giants</p>\n</blockquote>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="attributions"\n title=""\n src="/interpreter/static/86-attributions-e8d043fd57d5d7991edcad0a28d09290-83a8b.png"\n srcset="/interpreter/static/86-attributions-e8d043fd57d5d7991edcad0a28d09290-8992e.png 163w,\n/interpreter/static/86-attributions-e8d043fd57d5d7991edcad0a28d09290-ae0a7.png 325w,\n/interpreter/static/86-attributions-e8d043fd57d5d7991edcad0a28d09290-83a8b.png 650w,\n/interpreter/static/86-attributions-e8d043fd57d5d7991edcad0a28d09290-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="links"\n title=""\n src="/interpreter/static/87-links-b07aac4738a897ef5ba27c46ceb19954-83a8b.png"\n srcset="/interpreter/static/87-links-b07aac4738a897ef5ba27c46ceb19954-8992e.png 163w,\n/interpreter/static/87-links-b07aac4738a897ef5ba27c46ceb19954-ae0a7.png 325w,\n/interpreter/static/87-links-b07aac4738a897ef5ba27c46ceb19954-83a8b.png 650w,\n/interpreter/static/87-links-b07aac4738a897ef5ba27c46ceb19954-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>\n<p>One final thank you to the organizers and sponsors of this conference, and for giving me an opportunity to present at my first ever conference.</p>\n<p>I’d like to also thank each of the attendees. Without you, each of us would be speaking to an empty room, and where’s the fun in that!?</p>\n<p>… and finally, I’d like to thank everyone who attended my NebraskaJS meetup, in particular <a href="https://twitter.com/mattdsteele?lang=en">Matthew Steele</a>, for invaluable advice and support with an earlier iteration of this talk. In addition, <a href="https://twitter.com/_philpl">Phil Plückthun</a> for some great advice, as well.</p>\n<p>\n <span\n class="gatsby-resp-image-wrapper"\n style="position: relative; display: block; ; max-width: 650px; margin-left: auto; margin-right: auto;"\n >\n <span\n class="gatsby-resp-image-background-image"\n style="padding-bottom: 56.25%; position: relative; bottom: 0; left: 0; background-image: url(\'\'); background-size: cover; display: block;"\n >\n <img\n class="gatsby-resp-image-image"\n style="width: 100%; height: 100%; margin: 0; vertical-align: middle; position: absolute; top: 0; left: 0; box-shadow: inset 0px 0px 0px 400px white;"\n alt="fin the-end-thats-all-folks"\n title=""\n src="/interpreter/static/88-fin-the-end-thats-all-folks-fff0f71d9a105177cd5b6ec7473d060f-83a8b.png"\n srcset="/interpreter/static/88-fin-the-end-thats-all-folks-fff0f71d9a105177cd5b6ec7473d060f-8992e.png 163w,\n/interpreter/static/88-fin-the-end-thats-all-folks-fff0f71d9a105177cd5b6ec7473d060f-ae0a7.png 325w,\n/interpreter/static/88-fin-the-end-thats-all-folks-fff0f71d9a105177cd5b6ec7473d060f-83a8b.png 650w,\n/interpreter/static/88-fin-the-end-thats-all-folks-fff0f71d9a105177cd5b6ec7473d060f-38f8d.png 800w"\n sizes="(max-width: 650px) 100vw, 650px"\n />\n </span>\n </span>\n </p>',
id:"/Users/okwen/www/gatsbyblog/content/blog/2017-10-27-css-in-js-benefits-drawbacks-and-tooling/index.md absPath of file >>> MarkdownRemark",timeToRead:25,fields:{slug:"/css-in-js-benefits-drawbacks-and-tooling"},frontmatter:{date:"October 28, 2017",draft:null,tags:["css","css in js","react","component styling","styled-components","glamorous"],title:"CSS In JS: Benefits, Drawbacks, and Tooling"}}],tagName:"css in js"}}}});
//# sourceMappingURL=path---tags-css-in-js-733b0b6ae26b107cf272.js.map