ts
// theme/index.ts
import '@theojs/lumen/theme'
ts
// theme/index.ts
/* 徽章样式 */
import '@theojs/lumen/badge'
/* 按钮 */
import '@theojs/lumen/button'
/* 配色 */
import '@theojs/lumen/colors'
/* 文档样式 */
import '@theojs/lumen/doc'
/* 容器(默认):左侧阴影样式 */
import '@theojs/lumen/doc-blocks'
/* 容器:边框样式 */
import '@theojs/lumen/doc-blocks-border'
/* 首页样式 */
import '@theojs/lumen/home'
/* 首页按钮 */
import '@theojs/lumen/home-blocks'
/* 图标 */
import '@theojs/lumen/icon'
/* 图片样式 */
import '@theojs/lumen/pic'
图标支持
使用 iconify-icon
时报错 [Vue warn]: Failed to resolve component: iconify-icon
.vitepress/config.mts
ts
import { defineConfig } from 'vitepress'
export default defineConfig({
vue: {
template: {
compilerOptions: { isCustomElement: (tag) => tag === 'iconify-icon' }
}
}
...
})
md
<iconify-icon icon="simple-icons:fontawesome"></iconify-icon>
<iconify-icon icon="line-md:iconify2-static"></iconify-icon>
<iconify-icon icon="cil:locomotive" height="36"></iconify-icon>
<iconify-icon icon="cil:paper-plane" width="36"></iconify-icon>
<iconify-icon icon="cil:truck" style="font-size: 18px" height="2em"></iconify-icon>
使用方法查看: https://iconify.design/docs/iconify-icon/
自定义组件 CSS
可以通过覆盖根级别的 CSS 变量来自定义默认主题的 CSS:
ts
// .vitepress/theme/index.ts
import DefaultTheme from 'vitepress/theme'
import '@theojs/lumen/theme'
import './var.css'
export default DefaultTheme
..
css
/* .vitepress/theme/var.css */
:root {
--Announcement-bg: var(--vp-button-alt-bg);
--Announcement-bg-hover: var(--vp-c-brand-soft);
}
查看默认组件 CSS 变量
内容来获取可以被覆盖的变量。
示例
容器
容器分为 左侧阴影样式(默认)
和 边框样式
如需切换至边框样式,可以在 theme/index.ts
中按以下顺序引入
.vitepress/theme/index.ts
ts
import '@theojs/lumen/doc-blocks-border'
import '@theojs/lumen/theme'
...
注意: 引入 doc-blocks-border
时要放在 @theojs/lumen/theme
之后,以确保边框样式覆盖默认样式。如果放在上方,可能会导致样式融合,不同效果相互影响。
输入
md
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
::: info
[这是一个链接](https://doc.theojs.cn/)
这是一段文字
:::
::: tip
[这是一个链接](https://doc.theojs.cn/)
这是一段文字
:::
::: warning
[这是一个链接](https://doc.theojs.cn/)
这是一段文字
:::
::: danger
[这是一个链接](https://doc.theojs.cn/)
这是一段文字
:::
::: details
[这是一个链接](https://doc.theojs.cn/)
这是一段文字
:::
输出
这是一段文字
自定义容器
输入
md
::: danger STOP
[这是一个链接](https://doc.theojs.cn/)
:::
::: details Click me to view the code
```js
console.log('Hello, VitePress!')
```
:::
输出
STOP
Click me to view the code
js
console.log('Hello, VitePress!')
GitHub 风格容器
输入
md
> [!NOTE]
>
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
> [!TIP]
>
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
> [!IMPORTANT]
>
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
> [!WARNING]
>
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
> [!CAUTION]
>
> [这是一个链接](https://doc.theojs.cn/)
>
> 这是一段文字
输出
徽章
vue
default^1.9.0betacautioncustom element<Badge type="info" text="default" />
<Badge type="tip" text="^1.9.0" />
<Badge type="warning" text="beta" />
<Badge type="danger" text="caution" />
<Badge type="info">custom element</Badge>
图片浅色与深色模式
输入
md
<!-- 浅色模式 -->
![](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQ-w7jYJD-PBaozaH5WdubTPnBdi-XcQ4N96w&usqp=CAU){.light-only}
<!-- 深色模式 -->
![](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRCHxR2C_q8ugOMQzSmMovD3ni-z1QqTopSjg&usqp=CAU){.dark-only}
<!-- 深色模式 -->
![](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRCHxR2C_q8ugOMQzSmMovD3ni-z1QqTopSjg&usqp=CAU#dark)
<!-- 浅色模式 -->
![](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQ-w7jYJD-PBaozaH5WdubTPnBdi-XcQ4N96w&usqp=CAU#light)
md
![浅色模式{.light-only}](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQ-w7jYJD-PBaozaH5WdubTPnBdi-XcQ4N96w&usqp=CAU)
![深色模式{.dark-only}](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRCHxR2C_q8ugOMQzSmMovD3ni-z1QqTopSjg&usqp=CAU)
![深色模式](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRCHxR2C_q8ugOMQzSmMovD3ni-z1QqTopSjg&usqp=CAU#dark)
![浅色模式](https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQ-w7jYJD-PBaozaH5WdubTPnBdi-XcQ4N96w&usqp=CAU#light)
输出