类合并转换器
将一组类合并编译为一个单独的类。灵感来源于 Windi CSS 的 编译模式 以及 @UltraCakeBakery 提出的 issue #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
ts
import transformerCompileClass from '@unocss/transformer-compile-class'
import { defineConfig } from 'unocss'
export default defineConfig({
// ...
transformers: [
transformerCompileClass(),
],
})
TIP
此预设包含在 unocss
包中,也可以从中导入:
ts
import { transformerCompileClass } from 'unocss'
使用方法
在类名字符串前添加 :uno:
来标记它们以进行合并编译。
例如:
html
<div class=":uno: text-center sm:text-left">
<div class=":uno: text-sm font-bold 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"
}
}
许可证
- MIT 许可证 © 2021-PRESENT Anthony Fu