Appearance
Markdown 拓展
Vitepress 使用 markdown-it
来对 Markdown 进行解析和渲染,最终转为 Vue 组件。
markdown-it
是一款功能强大的 Markdown 解析器,支持丰富的 Markdown 语法,能够轻松将 Markdown 文本转换为 HTML 格式,并提供了许多语法扩展和插件。如果希望文章页拓展一些新的功能、UI,那么可以利用它拦截并处理 Markdown 生成的 HTML。
阅读 Vitepress 的代码可以发现,它利用 markdown-it
添加了代码块高亮、代码块行号、Tip 容器等功能,在 Vitepress 官网的 Markdown 里,已经详细介绍了 Vitepress 支持 Markdown 额外拓展的功能。
Teeker 也提供了几个 Markdown 插件,分别为:
- TODO 待办列表
- center 内容居中容器
- right 内容居右容器
- shareCard 分享卡片
- imgCard 图文卡片
- navCard 导航卡片
- codeArrow 代码块箭头
center
和 right
容器是一种简单的 Markdown 容器(不改变内容,只给内容加样式),Teeker 支持定义类似的容器,具体请看markdownContainers 配置项。
shareCard
、imgCard
、navCard
是基于 Markdown 容器实现(改变内容和样式),如果你也想定义类似的容器,可以阅读这三个插件的代码,它们的代码逻辑非常相似且简单,只需要会编写 HTML、CSS,就可以实现一个容器。
TODO 待办列表
效果:
- 吃饭
- 睡觉
- 打豆豆
输入:
markdown
- [ ] 吃饭
- [ ] 睡觉
- [x] 打豆豆
1
2
3
2
3
确保 [ ]
里有一个空格。
提示
支持所有列表语法,如:1.
、-
、+
、*
等。
内容居中容器
2021-11-13 @Teeker
测试标题
(测试二级标题)
内容居右容器
居右的内容字体为 14px
。
测试 right
摘要
很久之前,我决定踏上的这条路,映照了我与未来的因果。
2021-11-13 @Teeker
shareCard 分享卡片
分享卡片容器,可用于 友情链接、项目推荐、诗词展示
等。
效果:
输入:
markdown
::: shareCard 3
```yaml
- name: George Chan
desc: 让我给你讲讲他的传奇故事吧
avatar: https://z3.ax1x.com/2021/09/30/4oKMVI.jpg
link: https://cyc0819.top/
bgColor: "#FFB6C1"
textColor: "#621529"
- name: butcher2000
desc: 即使再小的帆,也能远航
avatar:
link: https://blog.csdn.net/weixin_46827107
bgColor: "#CBEAFA"
textColor: "#6854A1"
- name: Evan's blog
desc: 前端的小学生
avatar: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
link: https://xugaoyi.com/
bgColor: "#B9D59C"
textColor: "#3B551F"
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
语法
markdown
::: shareCard <每行显示数量>
```yaml
- name: 名称
desc: 描述
avatar: https://xxx.jpg # 头像,可选
link: https://xxx/ # 链接,可选
bgColor: "#CBEAFA" # 背景色,可选,默认 var(--vp-c-gray-1)。颜色值有 # 号时请添加引号
textColor: "#6854A1" # 文本色,可选,默认 var(--vp-c-text-1)
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
markdown
::: shareCard <每行显示数量>
```yaml
config:
cardNum: 3 # 每行显示的卡片数量,默认为 3,可在容器名字后面添加,如 ::: shareCard 3
target: _blank # 跳转方式,默认为 _blank,仅支持 _blank | _self
cardGap: 20 # 每行卡片之间的间隔,默认为 20
showCode: false # 是否显示代码块,默认为 false
data:
- name: 名称
desc: 描述
avatar: https://xxx.jpg # 头像,可选
link: https://xxx/ # 链接,可选
bgColor: "#CBEAFA" # 背景色,可选,默认 var(--vp-c-gray-1)。颜色值有 # 号时请添加引号
textColor: "#6854A1" # 文本色,可选,默认 var(--vp-c-text-1)
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
ts
export declare namespace ShareCard {
export interface Props {
config?: Config;
data: Item[];
}
export interface Config {
/**
* 每行显示的卡片数量
*
* @default 3
*/
cardNum?: number;
/**
* 跳转方式
*
* @default '_blank'
*/
target?: "_blank" | "_self";
/**
* 每行卡片之间的间隔
*
* @default 20
*/
cardGap?: number;
/**
* 是否显示代码块
*/
showCode?: boolean;
}
export interface Item {
/**
* 名称
*/
name: string;
/**
* 描述
*/
desc: string;
/**
* 头像
*/
avatar?: string;
/**
* 跳转链接
*/
link?: string;
/**
* 背景色
* @default var(--vp-c-gray-1)
*/
bgColor: string;
/**
* 文字颜色
* @default var(--vp-c-text-1)
*/
textColor: string;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<每行显示数量>
数字,表示每行最多显示多少个,选值范围1~4
,默认3
。在小屏时会根据屏幕宽度减少每行显示数量- 代码块需指定语言为
yaml
imgCard 图文卡片
图文卡片容器,可用于 项目展示、产品展示
等。
效果:
输入:
yaml
::: imgCard 3
```yaml
- img: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
link: https://xugaoyi.com/
name: 标题
desc: 描述内容描述内容描述内容描述内容 # 描述,可选
author: Teeker # 作者,可选
avatar: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png # 头像,可选
- img: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
link: https://xugaoyi.com/
name: 标题
desc: 描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容
author: Teeker
avatar: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
- img: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
link: https://xugaoyi.com/
name: 标题
desc: 描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容描述内容
author: Teeker
avatar: https://testingcf.jsdelivr.net/gh/Kele-Bingtang/static/user/avatar1.png
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
语法
markdown
::: imgCard <每行显示数量>
```yaml
- img: https://abc.jpg # 图片地址
link: https://abc.com # 链接地址
name: 标题
desc: 描述 # 可选
author: 作者名称 # 可选
avatar: https://abc.jpg # 作者头像,可选
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
markdown
::: imgCard <每行显示数量>
```yaml
config:
cardNum: 3 # 每行显示的卡片数量,默认为 3,可在容器名字后面添加,如 ::: imgCard 3
target: _blank # 跳转方式,默认为 _blank,仅支持 _blank | _self
lineClamp: 2 # 显示描述信息的行数,默认为 2
cardGap: 20 # 每行卡片之间的间隔,默认为 20
imgHeight: auto # 图片宽度,默认为 auto。仅图文卡片支持该配置项
objectFit: cover # 设置图片的填充方式,支持 cover | fill | contain | scale-down | none,默认为 cover
showCode: false # 是否显示代码块,默认为 false
data:
- img: https://abc.jpg # 图片地址
link: https://abc.com # 链接地址
name: 标题
desc: 描述 # 可选
author: 作者名称 # 可选
avatar: https://abc.jpg # 作者头像,可选
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
ts
export declare namespace ImgCard {
export interface Props {
config?: Config;
data: Item[];
}
export interface Config {
/**
* 每行显示的卡片数量
*
* @default 3
*/
cardNum?: number;
/**
* 跳转方式
*
* @default '_blank'
*/
target?: "_blank" | "_self";
/**
* 图片宽度
*
* @default 'auto'
*/
imgHeight?: string;
/**
* 设置图片的填充方式,为 CSS object-it 属性值
*
* @default 'cover'
*/
objectFit?: "cover" | "fill" | "contain" | "scale-down" | "none";
/**
* 显示描述信息的行数
*
* @default 2
*/
lineClamp?: number;
/**
* 每行卡片之间的间隔
*
* @default 20
*/
cardGap?: number;
/**
* 是否显示代码块
*/
showCode?: boolean;
}
export interface Item {
/**
* 图片链接
*/
img: string;
/**
* 跳转链接
*/
link?: string;
/**
* 名称
*/
name: string;
/**
* 描述
*/
desc?: string;
/**
* 作者
*/
author?: string;
/**
* 作者头像
*/
avatar?: string;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<每行显示数量>
数字,表示每行最多显示多少个,选值范围1~4
,默认3
。在小屏时会根据屏幕宽度减少每行显示数量- 代码块需指定语言为
yaml
navCard 导航卡片
导航卡片容器,可以用于制作 导航站点
效果:
输入:
yaml
::: navCard 3
```yaml
- name: 百度
desc: 百度——全球最大的中文搜索引擎及最大的中文网站,全球领先的人工智能公司
link: http://www.baidu.com/
img: https://img.tukuppt.com/png_preview/00/10/46/IHk8cns6Re.jpg!/fw/780
badge: 搜索引擎
- name: Google
desc: 全球最大的搜索引擎公司
link: http://www.google.com/
img: https://img.xiaoying.org.cn/img/202505301958073.png
badge: 搜索引擎
badgeType: tip
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
语法
markdown
::: navCard <每行显示数量>
```yaml
- name: 标题
desc: 描述
link: 链接地址 # 可选
img: 图片地址 # 可选
badge: 徽章内容 # 可选
badgeType: 徽章类型 # 可选
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
markdown
::: imgCard <每行显示数量>
```yaml
config:
cardNum: 3 # 每行显示的卡片数量,默认为 3,可在容器名字后面添加,如 ::: imgCard 3
target: _blank # 跳转方式,默认为 _blank,仅支持 _blank | _self
lineClamp: 2 # 显示描述信息的行数,默认为 2
cardGap: 20 # 每行卡片之间的间隔,默认为 20
showCode: false # 是否显示代码块,默认为 false
data:
- name: 标题
desc: 描述
link: 链接地址 # 可选
img: 图片地址 # 可选
badge: 徽章内容 # 可选
badgeType: 徽章类型 # 可选
```
:::
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
ts
export declare namespace NavCard {
export interface Props {
config?: Config;
data: Item[];
}
export interface Config {
/**
* 每行显示的卡片数量
*
* @default 3
*/
cardNum?: number;
/**
* 跳转方式
*
* @default '_blank'
*/
target?: "_blank" | "_self";
/**
* 显示描述信息的行数
*
* @default 2
*/
lineClamp?: number;
/**
* 每行卡片之间的间隔
*
* @default 20
*/
cardGap?: number;
/**
* 是否显示代码块
*/
showCode?: boolean;
}
export interface Item {
/**
* 名称
*/
name: string;
/**
* 描述
*/
desc: string;
/**
* 图片链接
*/
img?: string;
/**
* 跳转链接
*/
link?: string;
/**
* 右上角徽章
*/
badge?: string;
/**
* 右上角徽章类型
*
* @default 'info'
*/
badgeType?: "info" | "tip" | "warning" | "danger";
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<每行显示数量>
数字,表示每行最多显示多少个,选值范围1~4
,默认3
。在小屏时会根据屏幕宽度减少每行显示数量- 代码块需指定语言为
yaml