Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emotion-js/emotion
๐ฉโ๐ค CSS-in-JS library designed for high performance style composition
https://github.com/emotion-js/emotion
babel-plugin css css-in-js emotion react reactjs
Last synced: 5 days ago
JSON representation
๐ฉโ๐ค CSS-in-JS library designed for high performance style composition
- Host: GitHub
- URL: https://github.com/emotion-js/emotion
- Owner: emotion-js
- License: mit
- Created: 2017-05-27T04:23:45.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2025-01-13T07:18:15.000Z (13 days ago)
- Last Synced: 2025-01-13T12:03:44.842Z (12 days ago)
- Topics: babel-plugin, css, css-in-js, emotion, react, reactjs
- Language: JavaScript
- Homepage: https://emotion.sh/
- Size: 23.8 MB
- Stars: 17,597
- Watchers: 96
- Forks: 1,115
- Open Issues: 343
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-react-native - emotion โ 5627 - Style as a function of state. (Components / Styling)
- awesome-react - emotion - CSS-in-JS library designed for high performance style composition (**Awesome React** [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome) / React)
- awesome-list - emotion - in-JS library designed for high performance style composition | emotion-js | 13472 | (JavaScript)
- awesome-emotion - GitHub
- awesome-f2e-libs - **emotion**
- awesome-react-native - emotion โ 5627 - Style as a function of state. (Components / Styling)
- awesome-github-star - emotion - in-JS library designed for high performance style composition | emotion-js | 16768 | (JavaScript)
- awesome-react - emotion - Library designed for writing CSS styles with JavaScript (Uncategorized / Uncategorized)
- awesome-react-native - emotion โ 5627 - Style as a function of state. (Components / Styling)
- awesome-fe - **emotion**
- awesome-web - emotion - components](https://github.com/styled-components/styled-components) \| [polished](https://github.com/styled-components/polished) | ([React](https://github.com/facebook/react/))
- stars - emotion-js/emotion - in-JS library designed for high performance style composition (HarmonyOS / Windows Manager)
- StarryDivineSky - emotion-js/emotion - in-JS ๅบ (ๅ็ซฏๅผๅๆกๆถๅ้กน็ฎ / ๅ ถไป_ๆๆฌ็ๆใๆๆฌๅฏน่ฏ)
- awesome-react-cn - emotion - Library designed for writing CSS styles with JavaScript (Uncategorized / Uncategorized)
- awesome-react - emotion - CSS-in-JS library designed for high performance style composition ` ๐ 20 days ago` (React [๐](#readme))
- awesome - emotion - CSS-in-JS library designed for high performance style composition. (Frontend frameworks & libraries)
- awesome - emotion - CSS-in-JS library designed for high performance style composition. (Frontend frameworks & libraries)
- awesome-react-native - emotion โ 5627 - Style as a function of state. (Components / Styling)
- awesome-starred - emotion-js/emotion - ๐ฉโ๐ค CSS-in-JS library designed for high performance style composition (css)
- awesome-star-libs - emotion-js / emotion - in-JSๅบไธไธบ้ซๆง่ฝ้ฃๆ ผ็ปๅ่่ฎพ่ฎก (็ฎๅฝ)
- best-of-react - GitHub - 17% open ยท โฑ๏ธ 17.05.2024): (Styling)
- awesome - emotion - ๐ฉโ๐ค CSS-in-JS library designed for high performance style composition (JavaScript)
- awesome - emotion-js/emotion - ๐ฉโ๐ค CSS-in-JS library designed for high performance style composition (JavaScript)
- awesome-learning-resources - emotion - Library designed for writing CSS styles with JavaScript (Uncategorized / Uncategorized)
- stars - emotion - in-JS library designed for high performance style composition | emotion-js | 17614 | (JavaScript)
- stars - emotion - in-JS library designed for high performance style composition | emotion-js | 17557 | (JavaScript)
README
emotion
The Next Generation of CSS-in-JS
> **Emotion 11 has been released ๐ [See the blog post](https://emotion.sh/docs/emotion-11)**
[![Backers on Open Collective](https://opencollective.com/emotion/backers/badge.svg)](#backers) [![Sponsors on Open Collective](https://opencollective.com/emotion/sponsors/badge.svg)](#sponsors) [![npm version](https://badge.fury.io/js/emotion.svg)](https://badge.fury.io/js/emotion)
[![Build Status](https://img.shields.io/circleci/project/github/emotion-js/emotion/main.svg)](https://circleci.com/gh/emotion-js/emotion)
[![codecov](https://codecov.io/gh/emotion-js/emotion/branch/main/graph/badge.svg)](https://codecov.io/gh/emotion-js/emotion)
![@emotion/css size](https://img.shields.io/bundlephobia/min/@emotion/css.svg?label=@emotion/css%20size)
![@emotion/css gzip size](https://img.shields.io/bundlephobia/minzip/@emotion/css.svg?label=@emotion/css%20gzip%20size)
![@emotion/react size](https://img.shields.io/bundlephobia/min/@emotion/react.svg?label=@emotion/react%20size)
![@emotion/react gzip size](https://img.shields.io/bundlephobia/minzip/@emotion/react.svg?label=@emotion/react%20gzip%20size)
![@emotion/styled size](https://img.shields.io/bundlephobia/min/@emotion/styled.svg?label=@emotion/styled%20size)
![@emotion/styled gzip size](https://img.shields.io/bundlephobia/minzip/@emotion/styled.svg?label=@emotion/styled%20gzip%20size)
[![slack](https://img.shields.io/badge/join-slack-green)](https://join.slack.com/t/emotion-slack/shared_invite/zt-rmtwsy74-2uvyFdz5uxa8OiMguJJeuQ)Emotion is a performant and flexible CSS-in-JS library. Building on many other CSS-in-JS libraries, it allows you to style apps quickly with string or object styles. It has predictable composition to avoid specificity issues with CSS. With source maps and labels, Emotion has a great developer experience and great performance with heavy caching in production.
# [๐ Demo Sandbox](https://codesandbox.io/s/pk1qjqpw67)
# [๐ Docs](https://emotion.sh/docs/introduction)
Frequently viewed docs:
- [Introduction](https://emotion.sh/docs/introduction)
- [Install](https://emotion.sh/docs/install)
- [CSS Prop](https://emotion.sh/docs/css-prop)
- [Styled Components](https://emotion.sh/docs/styled)
- [Composition](https://emotion.sh/docs/composition)
- [Nested Selectors](https://emotion.sh/docs/nested)
- [Media Queries](https://emotion.sh/docs/media-queries)### Quick Start
Get up and running with a single import.
```bash
npm install --save @emotion/react
``````jsx
/** @jsx jsx */
import { jsx } from '@emotion/react'let SomeComponent = props => {
return (
)
}
```### Do I Need To Use the Babel Plugin?
The babel plugin is not required, but enables some optimizations and customizations that could be beneficial for your project.
Look here ๐ _[emotion babel plugin feature table and documentation](https://github.com/emotion-js/emotion/tree/main/packages/babel-plugin)_
### Demo Sandbox
[Demo Code Sandbox](https://codesandbox.io/s/pk1qjqpw67)
### Examples
- [emotion website](site) [[Demo Here](https://emotion.sh)]
- [next-hnpwa-guide-kit](https://github.com/tkh44/next-hnpwa-guide-kit) [[Demo Here](https://hnpwa.life)]
- [reactivesearch](https://github.com/appbaseio/reactivesearch), a react UI library for Elasticsearch [[Website](https://opensource.appbase.io/reactivesearch/)]
- [circuit-ui](https://github.com/sumup-oss/circuit-ui), a react component library built at SumUp [[Storybook](https://circuit.sumup.com/?path=/story/introduction-welcome--page)]
- **open a PR and add yours!**### Ecosystem
- [stylelint](https://github.com/stylelint/stylelint) - A mighty, modern linter that helps you avoid errors and enforce conventions in your styles.
- [facepaint](https://github.com/emotion-js/facepaint)
- [emotion-vue](https://github.com/egoist/emotion-vue)
- [nuxt-community/emotion-module](https://github.com/nuxt-community/emotion-module) - Emotion module for Nuxt.js
- [ember-emotion](https://github.com/alexlafroscia/ember-emotion)
- [CSS to emotion transform](https://transform.now.sh/css-to-emotion/)
- [ShevyJS](https://github.com/kyleshevlin/shevyjs)
- [design-system-utils](https://github.com/mrmartineau/design-system-utils) - Utilities to give better access to your design system.
- [polished](https://github.com/styled-components/polished) - Lightweight set of Sass/Compass-style mixins/helpers for writing styles in JavaScript.
- [monad-ui](https://github.com/muhajirdev/monad-ui/) - Utility First CSS-In-JS
- [css-in-js-media](https://github.com/zx6658/css-in-js-media) - you can deal with responsive design using css-in-js easily with this `css-in-js-media` which is similar with include-media
- [emotion-native-extended](https://github.com/ItsWendell/emotion-native-extended) - Better styling support for Emotion Native with [React Native Extended Stylesheet](https://github.com/vitalets/react-native-extended-stylesheet)### In the Wild
- [feathery.io](https://feathery.io)
- [frontity.org](https://frontity.org)
- [abacusfi.com](https://abacusfi.com)
- [healthline.com](https://www.healthline.com)
- [nytimes.com](https://www.nytimes.com)
- [vault.crucible.gg](http://vault.crucible.gg/)
- [render.com](https://render.com)
- [gatsbythemes.com](https://gatsbythemes.com/)
- [blazity.com](https://blazity.com/)
- [postmates.com](https://postmates.com/)
- [thedisconnect.co](https://thedisconnect.co/one)
- [zefenify.com](https://zefenify.com/about.html)
- [sentry.io](https://sentry.io)
- [comparett.com](https://comparett.com)
- [Domain.com.au](https://www.domain.com.au)
- [cyberhaven.com](https://cyberhaven.com)
- [CommercialRealEstate.com.au](https://www.commercialrealestate.com.au)
- [codecademy.com](https://www.codecademy.com)
- [Apache Superset](https://superset.apache.org/)## Sponsors
Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [[Become a sponsor](https://opencollective.com/emotion#sponsor)]
## Backers
Thank you to all our backers! ๐ [[Become a backer](https://opencollective.com/emotion#backer)]
## Contributors
This project exists thanks to all the people who contribute. [[Contribute](CONTRIBUTING.md)].