Skip to content

The world fastest framework agonistic CSS-in-JS library. Available in any frontend framework you use, like React, Vue and Svelte.

License

Notifications You must be signed in to change notification settings

winston0410/glory

Repository files navigation

Camouflage

🚀🚀🚀 The world fastest framework agonistic CSS-in-JS library.

Test Coverage Codacy Badge Known Vulnerabilities

Out run big-name popular CSS-in-JS libraries like Emotion, Styletron and Fela but with identical or even better supports.

Don't you believe me? Check out the benchmark here.

Features

  • Lightweight and modular. Install only what you need.

  • 🔥 Blazing fast.

  • 🌏 Framework agonistic.

  • Well-tested.

  • 🚑 Provide optional prefixer plugin.

  • 💅 Support nesting, keyframes and media-queries.

  • 🚧 Isomorphic. Support SSR/SSG server side render style rehydration. Unnecessary re-render is avoided.

Installation

A 0.1.0 will be released soon.

Sponsor

Support this package by becoming our sponsor.

Getting started

See our quick start guide for more details.

import { create as createCamoflage } from 'camouflage'
import prefixer from 'camouflage/prefixer'
import hydration from 'camouflage/hydration'
import virtual from 'camouflage/virtual'

const camouflage = create({
	//Config renderer here
})

//Use plugin to upgrade the default renderer

//Select your preferred styling interface
virtual(camouflage)
//Add support for auto-prefixing if needed
prefixer(camouflage)
//Add style hydration supports, if you will render styling beforehand in server
hydration(camouflage)

const style = {
	color: 'red',
	paddingTop: '100px',
	'@media screen': {
		//supports media queries
		color: 'red'
	},
	':hover': {
		//supports pesudo-classes and selectors
		backgroundColor: 'blue'
	}
}

const className = camouflage.virtual(style)
//return 'a b c d' as class name for maximum performance

//Insert .a{color:red;}.b{padding-top:100px;}@media screen{.c{color:red;}}.d:hover{background-color:blue;} as styling

Made in Hong Kong

This library is made by Hong Kongers.

Benchmarks

You can test the benchmark in your computer by cloning this repo and cd benchmarks. You can find all benchmarking commands in that package.json there.

Without prefixer, virtual()

$ node -r esm renderStyle/css.spec.js
nano-css("^5.3.1"), rule() x 121,604 ops/sec ±20.27% (64 runs sampled)
nano-css("^5.3.1"), virtual() x 395,781 ops/sec ±0.38% (92 runs sampled)
emotion("^11.1.3") x 381,874 ops/sec ±0.32% (98 runs sampled)
styletron("^1.4.6") x 816,730 ops/sec ±0.31% (97 runs sampled)
fela("^11.5.2") x 1,352,522 ops/sec ±1.11% (93 runs sampled)
camouflage, rule() x 324,168 ops/sec ±49.39% (56 runs sampled)
camouflage, virtual() x 1,357,795 ops/sec ±0.63% (94 runs sampled)
Fastest is camouflage, virtual(),fela("^11.5.2")

With prefixer, virtual()

$ node -r esm renderStyle/css-prefixed.spec.js
nano-css("^5.3.1"), rule() x 79,994 ops/sec ±16.18% (70 runs sampled)
nano-css("^5.3.1"), virtual() x 174,209 ops/sec ±1.19% (85 runs sampled)
emotion("^11.1.3") x 252,219 ops/sec ±1.64% (90 runs sampled)
goober("^2.0.21") x 98,742 ops/sec ±2.60% (57 runs sampled)
fela("^11.5.2") x 437,485 ops/sec ±3.97% (82 runs sampled)
styletron("^1.4.6") x 394,933 ops/sec ±1.32% (90 runs sampled)
camouflage, rule() x 249,918 ops/sec ±4.25% (57 runs sampled)
camouflage, virtual() x 1,002,094 ops/sec ±5.58% (72 runs sampled)
Fastest is camouflage, virtual()

With prefixer, jsx()

$ node -r esm renderStyle/css-jsx.spec.js
styled component x 42,740 ops/sec ±2.68% (85 runs sampled)
emotion, styled() x 1,552,696 ops/sec ±4.02% (73 runs sampled)
goober x 159,692,337 ops/sec ±1.85% (86 runs sampled)
camouflage, jsx() x 167,172,392 ops/sec ±1.34% (86 runs sampled)
Fastest is camouflage, jsx()

Difference between nano-css and camouflage

This library is a folk of nano-css, with the following difference:

  • renderer.put() is no longer the default.

  • Handle array values without needing array add-on.

Contribution

To contribute in this project, you need to do the followings:

  • Fork this repo and then clone your fork into your computer.

  • Contribute in your fork, commit and push to your fork.

  • Create a pull request in this repo.

After your code had been reviewed, accepted and merged into this repo, you contribution will be shown in this repo.

Roadmap

You can check our development roadmap here

Inspirations

This library is developed based on the good work of nano-css. This library would not be possible without their awesome test code.

These two libraries have enlightened me with the potential of atomic css.

About

The world fastest framework agonistic CSS-in-JS library. Available in any frontend framework you use, like React, Vue and Svelte.

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Contributors 3

  •  
  •  
  •