Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/streamich/nano-css
Distilled CSS-in-JS for gourmet developers
https://github.com/streamich/nano-css
css css-in-js css-in-react cssom emotion js nano styled-components styles stylesheets ts
Last synced: 3 days ago
JSON representation
Distilled CSS-in-JS for gourmet developers
- Host: GitHub
- URL: https://github.com/streamich/nano-css
- Owner: streamich
- License: unlicense
- Created: 2018-03-12T19:02:05.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2025-01-01T04:04:25.000Z (11 days ago)
- Last Synced: 2025-01-01T16:12:15.711Z (10 days ago)
- Topics: css, css-in-js, css-in-react, cssom, emotion, js, nano, styled-components, styles, stylesheets, ts
- Language: JavaScript
- Homepage:
- Size: 2.57 MB
- Stars: 435
- Watchers: 8
- Forks: 24
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-list - nano-css - in-JS for gourmet developers | streamich | 347 | (JavaScript)
- stars - nano-css - in-JS for gourmet developers | streamich | 435 | (JavaScript)
- stars - nano-css - in-JS for gourmet developers | streamich | 432 | (JavaScript)
README
# nano-css
[![][npm-badge]][npm-url] [![][travis-badge]][travis-url]
__Tiny [5th generation](https://github.com/streamich/freestyler/blob/master/docs/en/generations.md#5th-generation) CSS-in-JS library__ that you can actually use in production.
__Motto of `nano-css` is simple__: *create the smallest possible CSS-in-JS library and provide all features of any other library through addons.*- __Only [0.5 Kb](https://bundlephobia.com/[email protected])__ in base configuration, *e.g. [`styled-components`](https://github.com/styled-components/styled-components) is [15.1Kb](https://bundlephobia.com/[email protected])*
- __Library-agnostic__ — use it standalone, with React, Preact, Vue.js, or any other library
- __Isomorphic__ — render on server and browser, generates stable class names, and re-hydrates
- __Performant__ — [*simply the fastest library*](https://github.com/streamich/CSS-IN-JS-Benchmarks/blob/master/RESULT.md); does not create wrapper components, does not use inline styles or inline `` elements, but caches all styles for re-use and injects CSS using `.insertRule()` for performance
- __`@media` queries__ and __animation `@keyframes`__ are supported
- __Auto-prefixes__ your styles
- __Extract CSS__ into external style sheet
- __Public domain__ — [Unlicense license](./LICENSE)> For pre-configured simple-to-use package see [`nano-theme`](https://github.com/streamich/nano-theme), which builds on top of `nano-css`.
## Reference
- [Installation](./docs/Installation.md)
- [Addons](./docs/Addons.md)
- [`put()`](./docs/put.md) — [*demo!*](https://codesandbox.io/s/nkovxrzyv4)
- [`rule()`](./docs/rule.md) — [*demo!*](https://codesandbox.io/s/oxlj92m1m9)
- [`drule()`](./docs/drule.md) — [*demo!*](https://codesandbox.io/s/9jq5zmm91p)
- [`sheet()`](./docs/sheet.md) — [*demo!*](https://codesandbox.io/s/wyw093m7kw)
- [`dsheet()`](./docs/dsheet.md) — [*demo!*](https://codesandbox.io/s/q7rx4981vq)
- [`jsx()`](./docs/jsx.md) — [*demo!*](https://codesandbox.io/s/5y63x88504)
- [`useStyles()`](./docs/useStyles.md) — [*demo!*](https://codesandbox.io/s/o5k9jjo306)
- [`withStyles()`](./docs/withStyles.md) — [*demo!*](https://codesandbox.io/s/5k3jvkk31l)
- [`decorator`](./docs/decorator.md) — [*demo № 1*](https://codesandbox.io/s/j442958125) and [*demo № 2*](https://codesandbox.io/s/3qjzv35941)
- [`component`](./docs/component.md) — [*demo!*](https://codesandbox.io/s/yk8pk4v95j)
- [`style()`](./docs/style.md) — [*demo!*](https://codesandbox.io/s/53qk3qkopn)
- [`styled()()`](./docs/styled.md) — [*demo!*](https://codesandbox.io/s/w667y036p5)
- [`hyperstyle()`](./docs/hyperstyle.md) — [*demo!*](https://codesandbox.io/s/wqny7z17x8)
- [`stable`](./docs/stable.md)
- [`atoms`](./docs/atoms.md) — [*demo!*](https://codesandbox.io/s/rlkxl6o9v4)
- [`emmet`](./docs/emmet.md)
- [`nesting`](./docs/nesting.md)
- [`keyframes()`](./docs/keyframes.md)
- [`hydrate()`](./docs/hydrate.md)
- [`prefixer`](./docs/prefixer.md)
- [`stylis`](./docs/stylis.md)
- [`unitless`](./docs/unitless.md)
- [`!important`](./docs/important.md)
- [`:global`](./docs/global.md)
- [`animate/*`](./docs/animations.md)
- [`reset/*`](./docs/resets.md)
- [`reset-font`](./docs/reset-font.md)
- [`googleFont()`](./docs/googleFont.md)
- [`limit`](./docs/limit.md)
- [`amp`](./docs/amp.md)
- [`virtual`](./docs/virtual.md)
- [`spread`](./docs/spread.md)
- [`array`](./docs/array.md)
- [`snake`](./docs/snake.md) — [*demo!*](https://codesandbox.io/s/mo7n1857zj)
- [`tachyons`](./docs/tachyons.md)
- [`rtl`](./docs/rtl.md)
- [`extract`](./docs/extract.md)
- [`sourcemaps`](./docs/sourcemaps.md)
- [`.units`](./docs/units.md)
- [`cssom`](./docs/cssom.md)
- [`vcssom`](./docs/vcssom.md)
- [Presets](./docs/Presets.md)
- [Server-side rendering](./docs/SSR.md)[npm-url]: https://www.npmjs.com/package/nano-css
[npm-badge]: https://img.shields.io/npm/v/nano-css.svg
[travis-url]: https://travis-ci.org/streamich/nano-css
[travis-badge]: https://travis-ci.org/streamich/nano-css.svg?branch=master