Skip to content

编译类转换器

将一组类编译为一个类。灵感来自 Windi CSS 的 编译模式 以及 @UltraCakeBakery 提出的 问题 #948

安装

bash
pnpm add -D @unocss/transformer-compile-class
bash
yarn add -D @unocss/transformer-compile-class
bash
npm install -D @unocss/transformer-compile-class
bash
bun add -D @unocss/transformer-compile-class
uno.config.ts
ts
import transformerCompileClass from '@unocss/transformer-compile-class'
import { defineConfig } from 'unocss'

export default defineConfig({
  // ...
  transformers: [
    transformerCompileClass(),
  ],
})

提示

此预设包含在 unocss 包中,你也可以从该包中导入它:

ts
import { transformerCompileClass } from 'unocss'

使用方法

在类名字符串的开头添加 :uno: 以标记它们进行编译。

例如:

html
<div class="text-center :uno: sm:text-left">
  <div class="text-sm font-bold :uno: hover:text-red" />
</div>

将被编译为:

html
<div class="uno-qlmcrp">
  <div class="uno-0qw2gr" />
</div>
css
.uno-qlmcrp {
  text-align: center;
}
.uno-0qw2gr {
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 700;
}
.uno-0qw2gr:hover {
  --un-text-opacity: 1;
  color: rgb(248 113 113 / var(--un-text-opacity));
}
@media (min-width: 640px) {
  .uno-qlmcrp {
    text-align: left;
  }
}

选项

你可以使用这些选项来配置编译类的触发字符串和前缀。有关详细信息,请参考 类型定义

工具

ESLint

有一个 ESLint 规则可在整个项目中强制使用类编译转换器:@unocss/enforce-class-compile

用法:

json
{
  "plugins": ["@unocss"],
  "rules": {
    "@unocss/enforce-class-compile": "warn"
  }
}

许可协议