---
title: 图标
createTime: 2024/09/30 14:49:39
icon: grommet-icons:emoji
permalink: /guide/markdown/icon/
badge:
text: 变更
type: warning
---
::: warning 图标语法糖在 `1.0.0-rc.144` 版本中进行了破坏性变更。
`:[collect:name size/color]:` 语法糖已弃用,请使用 `::collect:name =size /color::` 代替。
主题计划在未来的版本中,支持如 `iconfont` / `fontawesome` / `lucide` 等图标库的图标,原有语法糖
不足以支持新的扩展,因此此破坏性变更是必要的。
旧的语法在近期的版本中依然支持,但不再推荐使用,且在未来会删除。
主题会检测是否使用旧的语法,如果使用,会在控制台输出警告信息和修改建议,请根据修改建议进行调整。
:::
## 概述
主题支持在 Markdown 文件中以下来源的图标:
- [iconify](https://iconify.design/) - 默认支持
- [iconfont](https://www.iconfont.cn/) - 可选
- [fontawesome](https://fontawesome.com/) - 可选
主题提供图标 markdown 语法支持,使用简单灵活的方式在 Markdown 中插入图标。
[主题还提供了 `` 组件支持,点击了解更多](../components/icon.md){.read-more}
## 语法
图标语法为行内语法,可以在段落中与其他 markdown 语法混合使用。
**基础语法**,使用 `::` 包裹图标名称:
```md
::name::
```
**设置图标大小和颜色**:(注意空格不可缺少)
```md
::name =size::
::name /color::
::name =size /color::
```
- `=size`: 设置图标大小
- `=16`: 图标的宽高为 `16px`
- `=24x16`: 图标的宽为 `24px`,高为 `16px`
- `=x16`: 图标的高为 `16px`,宽为自适应
- `=1.2em`: 图标的宽高为 `1.2em`
- `=1.2emx1.5em`: 图标的宽为 `1.2em`,高为 `1.5em`
- `/color`: 设置图标颜色,支持 `hex`/ `rgb` / `rgba` / `hsl` / `hsla` 等合法颜色色值
- `/#fff` : 图标的颜色为 `#fff`
- `/rgb(255,0,0)`: 图标的颜色为 `rgb(255,0,0)`
## Iconify
[iconify](https://iconify.design/) 提供了 **200K +** 的开源图标支持,足以满足大多数项目的需求。
主题将 **iconify** 作为默认的图标来源支持。
在 Markdown 中使用 `::collect:name` 语法来插入图标。
### 配置
```ts title=".vuepress/config.ts" twoslash
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
markdown: { // [!code ++:3]
icon: { provider: 'iconify' } // 默认支持
}
})
})
```
```ts
interface IconOptions {
provider: 'iconify'
prefix?: string
}
```
### 使用
::: steps
- 从 [iconify search](https://icon-sets.iconify.design/) 搜索想要使用的图标,复制图标名称:

- 在 Markdown 中使用 `::collect:name` 语法来插入图标
```md
::carbon:home::
```
**输出:** ::carbon:home::
:::
在 Iconify 中,图标被分为不同的 `collect`,每个 `collect` 下有若干个图标。
在 `::collect:name` 语法中,使用 `:` 来分隔 `collect` 和 `name`。
如果你主要使用某个 `collect` 下的图标,可以在配置中指定 `prefix`, 以便在 `::collect:name` 语法中省略 `collect` 前缀:
```ts title=".vuepress/config.ts" twoslash
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
markdown: {
icon: {
provider: 'iconify',
prefix: 'carbon', // 默认使用 `collect` 图标集合 // [!code ++]
}
}
})
})
```
```md
::home::
::solar:user-bold::
```
**输出:** ::carbon:home:: ::solar:user-bold::
### 安装
对于企业内部项目,或无法访问外部网络资源的情况下,主题推荐安装 `@iconify/json` 依赖。
主题自动解析 `@iconify/json` 中的图标数据,将已使用的图标打包为本地资源。
::: npm-to
```sh
npm install @iconify/json
```
:::
### 示例
输入:
```md
github: ::tdesign:logo-github-filled::
修改颜色:::tdesign:logo-github-filled /#f00::
修改大小:::tdesign:logo-github-filled =36px::
修改大小颜色:::tdesign:logo-github-filled =36px /#f00::
彩色图标 ::skill-icons:vscode-dark =36px::
```
输出:
github: ::tdesign:logo-github-filled::
修改颜色:::tdesign:logo-github-filled /#f00::
修改大小:::tdesign:logo-github-filled =36px::
修改大小颜色:::tdesign:logo-github-filled =36px /#f00::
彩色图标 ::skill-icons:vscode-dark =36px::
## Iconfont
[iconfont](https://www.iconfont.cn/) 是提供了海量的图标支持。
### 配置
```ts title=".vuepress/config.ts" twoslash
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
markdown: { // [!code ++:3]
icon: {
provider: 'iconfont',
assets: 'https://at.alicdn.com/t/c/xxxx.css' // 示例地址
}
}
})
})
```
```ts
interface IconOptions {
provider: 'iconfont'
/**
* 图标前缀
* @default 'iconfont icon-'
*/
prefix?: string
/**
* iconfont 资源地址
*/
assets: string | string[]
}
```
### 使用
[前往 **iconfont 帮助中心** 了解 **创建项目**和 **添加图标**](https://www.iconfont.cn/help/detail){.read-more}
:::steps
- 从 iconfont 获取项目的资源地址,复制并粘贴到 `assets` 配置中:

```ts title=".vuepress/config.ts"
export default defineUserConfig({
theme: plumeTheme({
markdown: {
icon: {
provider: 'iconfont',
assets: 'https://at.alicdn.com/t/c/xxxx.css' // 示例地址 // [!code ++]
}
}
})
})
```
也可以选择下载至本地,将资源存放到 `.vuepress/public` 目录中,然后在 `assets` 配置中填写本地文件路径。
- 检查 iconfont 的项目配置,获取 `prefix` 配置:

其中 `prefix` 配置由 `font family` 和 `font class` 前缀组成,如果 iconfont 的项目配置为默认配置,
则 `prefix` 为 `iconfont icon-`,此时你可以忽略此步骤。
```ts title=".vuepress/config.ts"
export default defineUserConfig({
theme: plumeTheme({
markdown: {
icon: {
provider: 'iconfont',
prefix: 'iconfont icon-', // 默认值 // [!code ++]
}
}
})
})
```
- 在 Markdown 中使用 `::name::` 语法来插入图标:

将图片中的 `font class` 填入 `::name::` 语法中:
```md
::hot::
::hot =24px::
::hot =24px /#f00::
```
输出:
:::
## Fontawesome
[Fontawesome](https://fontawesome.com/) 提供了 免费 和 付费 的图标支持,付费图标需要进行订阅。
[查看 **Fontawesome** 官方文档](https://docs.fontawesome.com/web/setup/get-started){.read-more}
### 配置
```ts title=".vuepress/config.ts" twoslash
import { defineUserConfig } from 'vuepress'
import { plumeTheme } from 'vuepress-theme-plume'
export default defineUserConfig({
theme: plumeTheme({
markdown: { // [!code ++:3]
icon: {
provider: 'fontawesome',
assets: 'fontawesome' // 预设资源地址,从 CDN 加载
}
}
})
})
```
```ts
interface IconOptions {
provider: 'fontawesome'
/**
* 图标前缀
* @default 'fas'
*/
prefix?: FontAwesomePrefix
/**
* iconfont 资源地址
*/
assets: (FontAwesomeAssetBuiltin | string)[]
}
type FontAwesomeAssetBuiltin = 'fontawesome' | 'fontawesome-with-brands'
type FontAwesomePrefix
= | 'fas' | 's' // fa-solid fa-name
| 'far' | 'r' // fa-regular fa-name
| 'fal' | 'l' // fa-light fa-name
| 'fat' | 't' // fa-thin fa-name
| 'fads' | 'ds' // fa-duotone fa-solid fa-name
| 'fass' | 'ss' // fa-sharp fa-solid fa-name
| 'fasr' | 'sr' // fa-sharp fa-regular fa-name
| 'fasl' | 'sl' // fa-sharp fa-light fa-name
| 'fast' | 'st' // fa-sharp fa-thin fa-name
| 'fasds' | 'sds' // fa-sharp-duotone fa-solid fa-name
| 'fab' | 'b' // fa-brands fa-name
```
[在 **Fontawesome** 中,图标通过 families + styles 控制样式,**查看详情**](https://docs.fontawesome.com/web/add-icons/how-to#setting-different-families--styles){.read-more}
为便于管理,可以通过 `::prefix:name::` 语法,通过前缀设置 families + styles,默认前缀为 `fas`,可以省略它:
```md
::name::
::fas:name::
::s:name::
```
可以通过配置 `markdown.icon.prefix` 修改默认前缀。
::: tip
Fontawesome 的免费图标仅支持 `solid` 、部分 `regular` 以及 `brands`,
对于免费版本,前缀仅支持 `fas` / `far` / `fab` 和它们的缩写前缀。
:::
### 使用
[前往 **https://fontawesome.com/search?ic=free** 搜索免费图标](https://fontawesome.com/search?ic=free){.read-more}
:::steps
- 复制图标名称:

- 在 Markdown 中使用 `::prefix:name::` 语法插入图标:
```md
::circle-user::
::fas:circle-user::
::s:circle-user::
```
:::
### 示例
```md
::circle-user::
::circle-user =24px::
::circle-user =24px /#f00::
```
输出:
[为 Fontawesome 添加更多样式支持](https://docs.fontawesome.com/web/style/styling){.read-more}
```
::circle-user 2xl::
::circle-user rotate-90::
::circle-user beat::
::circle-user border::
::circle-user 2xl beat::
```
输出:
## 其它说明
当 `markdown.icon.provider` 设置为非 `iconify` 时,`iconify` 作为默认支持,依然可以在
markdown 中插入 iconify 图标:
在 `::collect:name::` 语法中,在开始位置添加 `iconify`:
```md /iconify /
::iconify carbon:home::
```
输出:
::iconify carbon:home::