迷你预设
UnoCSS 的基础预设,仅包含最基本的实用工具。
安装
bash
pnpm add -D @unocss/preset-mini
bash
yarn add -D @unocss/preset-mini
bash
npm install -D @unocss/preset-mini
bash
bun add -D @unocss/preset-mini
ts
import presetMini from '@unocss/preset-mini'
import { defineConfig } from 'unocss'
export default defineConfig({
presets: [
presetMini(),
// ...其他预设
],
})
TIP
此预设已包含在 unocss
包中,你也可以从那里导入:
ts
import { presetMini } from 'unocss'
规则
此预设是 @unocss/preset-wind3
的子集,仅包含与 CSS 属性最紧密相关的基本实用工具,但排除了 Tailwind CSS 中的有主观性或复杂的实用工具(如 container
、animation
、gradient
等)。这可以作为基于 Tailwind CSS 或 Windi CSS 熟悉实用工具的自定义预设的良好起点。
特性
暗黑模式
默认情况下,此预设通过 dark:
变体生成基于类的暗黑模式。
html
<div class="dark:bg-red:10" />
将生成:
css
.dark .dark\:bg-red\:10 {
background-color: rgb(248 113 113 / 0.1);
}
基于媒体查询的暗黑模式
要全局使用基于媒体查询的暗黑模式,可以更改 dark:
变体的配置:
ts
presetMini({
dark: 'media'
})
现在
html
<div class="dark:bg-red:10" />
将生成:
css
@media (prefers-color-scheme: dark) {
.dark\:bg-red\:10 {
background-color: rgb(248 113 113 / 0.1);
}
}
CSS @layer
支持 CSS 原生 @layer,使用 layer-xx:
变体
html
<div class="layer-foo:p4" />
<div class="layer-bar:m4" />
将生成:
css
@layer foo {
.layer-foo\:p4 {
padding: 1rem;
}
}
@layer bar {
.layer-bar\:m4 {
margin: 1rem;
}
}
主题
你可以在配置中完全自定义主题属性,UnoCSS 将最终深度合并到默认主题。
WARNING
breakpoints
属性不会深度合并,而是被覆盖,请参见 断点。
ts
presetMini({
theme: {
// ...
colors: {
veryCool: '#0000ff', // class="text-very-cool"
brand: {
primary: 'hsl(var(--hue, 217) 78% 51%)', // class="bg-brand-primary"
}
},
}
})
选项
dark
- 类型:
class | media | DarkModeSelectors
- 默认值:
class
暗黑模式选项。可以是 class
、media
或自定义选择器对象(DarkModeSelectors
)。
ts
interface DarkModeSelectors {
/**
* 亮色变体的选择器。
*
* @default '.light'
*/
light?: string
/**
* 暗色变体的选择器。
*
* @default '.dark'
*/
dark?: string
}
attributifyPseudo
- 类型:
Boolean
- 默认值:
false
生成伪选择器为 [group=""]
而不是 .group
。
variablePrefix
- 类型:
string
- 默认值:
un-
CSS 自定义属性的前缀。
prefix
- 类型:
string | string[]
- 默认值:
undefined
实用工具前缀。
preflight
- 类型:
boolean
|on-demand
- 默认值:
true
生成预处理 CSS。可以是:
true
:始终生成预处理。false
:不生成预处理。on-demand
:仅为使用的实用工具生成预处理。