Component level cssinjs solution used in ant.design. It’s a subset of Emotion with design token logic wrapper. Please feel free to use emotion directly if you want to find a web cssinjs solution. cssinjs related dep packages:
@ant-design/cssinjs is released under the MIT license.
API
StyleProvider
Prop
Desc
Type
Default
autoClear
Clear inject style element when component remove.
boolean
false
cache
Config cssinjs cache entity. Only set when you need ssr to extract style on you own.
CacheEntity
-
hashPriority
Use :where selector to reduce hashId css selector priority
'low' | 'high'
'low'
container
Tell cssinjs where to inject style in.
Element | ShadowRoot
document.head
ssrInline
Component wil render inline <style /> for fallback in SSR. Not recommend.
boolean
false
transformers
Transform css before inject in document. Please note that transformers do not support dynamic update
Transformer[]
-
createCache
return CacheEntity for StyleProvider.
createTheme
Create theme object. When same algorithm provided, it will return same object.
Design Token related API
Since @ant-design/cssinjs use strong constraints for cache hit performance, we recommend to view demo basic.tsx for usage and animation.tsx for animation usage.
extractStyle
Extracts the styles from the cache and returns them as a string.
Parameters
cache (Cache): The cache instance containing the styles.
options (object | boolean, optional): Options for extracting the styles.
plain (boolean, optional): If true, the styles will be returned in plain format. Default is false.
types (string | string[], optional): The types of styles to extract. Default is [‘style’, ‘token’, ‘cssVar’].
@ant-design/cssinjs
Component level cssinjs solution used in ant.design. It’s a subset of Emotion with design token logic wrapper. Please feel free to use emotion directly if you want to find a web cssinjs solution. cssinjs related dep packages:
Live Demo
https://ant-design.github.io/cssinjs/
Install
or
Development
License
@ant-design/cssinjs is released under the MIT license.
API
StyleProvider
:whereselector to reduce hashId css selector priority'low' | 'high''low'document.head<style />for fallback in SSR. Not recommend.transformersdo not support dynamic updatecreateCache
return CacheEntity for StyleProvider.
createTheme
Create theme object. When same algorithm provided, it will return same object.
Design Token related API
Since
@ant-design/cssinjsuse strong constraints for cache hit performance, we recommend to view demobasic.tsxfor usage andanimation.tsxfor animation usage.extractStyle
Extracts the styles from the cache and returns them as a string.
Parameters
cache(Cache): The cache instance containing the styles.options(object | boolean, optional): Options for extracting the styles.plain(boolean, optional): If true, the styles will be returned in plain format. Default is false.types(string | string[], optional): The types of styles to extract. Default is [‘style’, ‘token’, ‘cssVar’].Returns
Example
Transform
When you need transform CSSObject before inject style. You can use
transformersto handle this:Follow are the transform we provide:
legacyLogicalPropertiesTransformer
Convert logical properties to legacy properties. e.g.
marginBlockStarttomarginTop:px2remTransformer
Convert pixel units to rem units. px2remTransformer.options