Go to file
2024-09-23 14:39:52 +08:00
.github/workflows test: use unified github action yml (#194) 2024-08-24 19:38:23 +08:00
docs fix: order of layer (#181) 2024-04-02 16:51:55 +08:00
src fix: root selector with single & (#193) 2024-08-22 16:16:45 +08:00
tests fix: root selector with single & (#193) 2024-08-22 16:16:45 +08:00
.dumirc.ts docs: update dumi config 2023-05-20 12:37:06 +08:00
.editorconfig Initial commit 2022-01-20 17:22:39 +08:00
.eslintrc.js Initial commit 2022-01-20 17:22:39 +08:00
.fatherrc.js chore: external react & react-dom 2023-11-22 20:43:33 +08:00
.gitignore test: use unified github action yml (#194) 2024-08-24 19:38:23 +08:00
.npmignore chore: fix ts lint 2022-01-26 11:48:19 +08:00
.prettierignore Initial commit 2022-01-20 17:22:39 +08:00
.prettierrc docs: update API list 2022-12-22 15:07:53 +08:00
bunfig.toml test: use unified github action yml (#194) 2024-08-24 19:38:23 +08:00
index.js Initial commit 2022-01-20 17:22:39 +08:00
jest.config.js fix: Compatible for useId with React 18 (#16) 2022-04-15 11:52:38 +08:00
LICENSE.md Initial commit 2022-01-20 17:22:39 +08:00
package.json test: use unified github action yml (#194) 2024-08-24 19:38:23 +08:00
README.md Add extractStyle API description to README (#196) 2024-09-23 14:39:52 +08:00
tsconfig.json chore: migrate jest to vitest (#110) 2023-05-10 09:38:46 +08:00
type.d.ts Initial commit 2022-01-20 17:22:39 +08:00
vitest-setup.ts chore: migrate jest to vitest (#110) 2023-05-10 09:38:46 +08:00
vitest.config.ts chore: migrate jest to vitest (#110) 2023-05-10 09:38:46 +08:00

@ant-design/cssinjs

NPM version npm download dumi build status Codecov bundle size

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:

  • stylis
  • @emotion/hash
  • @emotion/unitless

Live Demo

https://ant-design.github.io/cssinjs/

Install

npm install @ant-design/cssinjs

or

yarn add @ant-design/cssinjs
pnpm add @ant-design/cssinjs

Development

npm install
npm start

License

@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.

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'].

Returns

  • (string): The extracted styles as a string.

Example

import { extractStyle, createCache } from '@ant-design/cssinjs';

// 创建并填充缓存
const cache = createCache();
// 注意:在实际使用中,缓存通常会在渲染组件时自动填充

// 提取样式
const styles = extractStyle(cache, { plain: true, types: ['style', 'token'] });

// 使用提取的样式
const styleElement = document.createElement('style');
styleElement.innerHTML = styles;
document.head.appendChild(styleElement);

Transform

When you need transform CSSObject before inject style. You can use transformers to handle this:

import {
  legacyLogicalPropertiesTransformer,
  StyleProvider,
} from '@ant-design/cssinjs';

export default () => (
  <StyleProvider transformers={[legacyLogicalPropertiesTransformer]}>
    <MyApp />
  </StyleProvider>
);

Follow are the transform we provide:

legacyLogicalPropertiesTransformer

Convert logical properties to legacy properties. e.g. marginBlockStart to marginTop:

  • inset
  • margin
  • padding
  • border

px2remTransformer

Convert pixel units to rem units. px2remTransformer.options