实现并显示一个小组件需要两个步骤:

  1. 【配置】在组件库中声明组件
  2. 【使用】在需要的位置调用

组件库在 _data/widgets.yml 文件中,需要自己创建,内容形如:

1
2
3
'我的小组件1':
layout: 小组件布局模板
...(其它属性)

使用的地方有:【主题配置】、【项目配置】、【页面】,后者可以覆盖前者,例如:

blog/source/_posts/xxx.md
1
2
3
---
leftbar: ['我的小组件1', '我的小组件2']
---

组件库

在创建组件时,您可以使用以下这些 layout 布局:

toc

这是文章/文档的目录树组件,显示文章和文档的目录结构:

blog/source/_data/widgets.yml
1
2
3
4
5
6
7
toc:
layout: toc
list_number: false # 是否显示序号
min_depth: 2 # 建议不要低于 2 即从 H2 标签开始解析(H1标签用于文章大标题)
max_depth: 5 # 5 代表最多解析到 H5 标签
fallback: recent # Use a backup widget when toc does not exist.
collapse: false # true / false / auto (始终折叠/不折叠/自动折叠)

tocfallback 默认是 recent,即一篇文章没有 TOC 的时候会显示一个 recent

recent

blog/source/_data/widgets.yml
1
2
3
4
recent:
layout: recent
rss: # /atom.xml # npm i hexo-generator-feed
limit: 5 # Count of posts

wiki 板块显示的是最近更新的 wiki 页面,其余地方显示最近更新的文章。

hexo 的覆盖规则是合并而不是替换,所以若不想使用 recent,除了在 _config.stellar.yml 中删除 recent 你还需要将此处的 recent 置空,即

blog/source/_data/widgets.yml
1
2
3
4
recent:
# layout: recent
# rss: # /atom.xml # npm i hexo-generator-feed
# limit: 5 # Count of posts

然后自己需要的地方用自己另建的一个 my_recent 组件

blog/source/_data/widgets.yml
1
2
3
my_recent:
layout: recent
...

相关文档组件,用于显示具有相同 tags 的其它项目列表,暂不支持自定义内容:

Stellar 1.12.0 已将 wiki_more,更名为 related

blog/source/_data/widgets.yml
1
2
related:
layout: related

columns 为1显示为列表,2是每两个按钮放一行,icontitle 会同时显示,大于2则只显示 icon

blog/source/_data/widgets.yml
1
2
3
4
5
6
7
linklist:
layout: linklist
columns: 1
items:
- icon: '<svg...></svg>' # 或者 icons.yml 中设置的 icon 名称
title: 关于
url: /about/

markdown

这是一个自由度很高的标签,可以显示 markdown 文本内容:

blog/source/_data/widgets.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
welcome:
layout: markdown
title: 欢迎欢迎
linklist: # 与 linklist 组件写法相同
columns: 1
items:
- icon:
title:
url:
content: |
欢迎使用 [Stellar](https://github.com/xaoxuu/hexo-theme-stellar/) 主题,下面是您的入门指南,祝您使用愉快!
<br>
**第一步**
创建 `blog/_config.stellar.yml` 文件,在此文件中填写需要自定义的主题配置。
<br>
**第二步**
创建 `blog/source/_data/widgets.yml` 文件,此文件中填写需要自定义的侧边栏组件,例如 `welcome` 组件。
<br>
如果有任何疑问,请先查阅 [文档](https://xaoxuu.com/wiki/stellar/),如果文档中没有提供,请提 [issue](https://github.com/xaoxuu/hexo-theme-stellar/issues/) 向开发者询问。
src: # 可以设置外部 md 文件链接

linklist 显示为嵌套在 md 组件中,效果参考

tagcloud

标签云组件:

blog/source/_data/widgets.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
tagcloud:
layout: tagcloud
title: 标签云
# 标签云配置
min_font: 12
max_font: 24
amount: 100
orderby: name
order: 1 # 1, sac 升序;-1, desc 降序
color: false # 使用颜色
start_color: # 开始的颜色。您可使用十六进位值('#b700ff'),rgba(rgba(183, 0, 255, 1)),hsla(hsla(283, 100%, 50%, 1))或 颜色关键字。此变量仅在 color 参数开启时才有用。
end_color: # 结束的颜色。您可使用十六进位值('#b700ff'),rgba(rgba(183, 0, 255, 1)),hsla(hsla(283, 100%, 50%, 1))或 颜色关键字。此变量仅在 color 参数开启时才有用。
show_count: false # 显示每个标签的文章总数

ghuser

显示 GitHub 用户基础信息卡片:

blog/source/_data/widgets.yml
1
2
3
4
5
ghuser:
layout: ghuser
username: github # your github login username
avatar: true # show avatar or not
menu: true # show menu or not

ghrepo

显示 GitHub 仓库基础信息,需要搭配 repo 一起使用:

blog/source/_data/widgets.yml
1
2
ghrepo:
layout: ghrepo

需要在需要显示的文章页面的 front-matter 中按照如下格式写上仓库持有者和仓库名:

blog/source/_posts/xxx.md
1
2
3
---
repo: xaoxuu/hexo-theme-stellar
---

如果需要显示在 wiki 项目中,则在 _data/wiki/projects.yml 中填写到对应项目的信息中:

blog/source/_data/wiki/projects.yml
1
2
3
4
5
name: Stellar
title: Stellar
subtitle: '每个人的独立博客 | Designed by xaoxuu'
repo: xaoxuu/hexo-theme-stellar
...

timeline

时间线组件,这个功能在 1.12.0 版本后开始支持:

动态数据是从 GitHub Issues 中拉取的,使用方法为:

widgets.yml 中新建配置

blog/source/_data/widgets.yml
1
2
3
4
5
6
timeline:
layout: timeline
title: 近期动态
api: https://api.github.com/repos/xaoxuu/hexo-theme-stellar/issues # 若你想限制数量,在api链接后面加上?per_page=1指限制为1条
user: # 是否过滤只显示某个人发布的内容,如果要筛选多人,用英文逗号隔开
hide: # title,footer # 隐藏标题或底部 # 此功能需要 Stellar v1.13.0

这个功能在 1.13.0 版本后开始支持。

blog/source/_data/widgets.yml
1
2
3
4
5
6
7
# 愣着干啥,新建啊
'朋友圈':
layout: timeline
title: 近期动态
api: https://api.vlts.cc/output_data/v1/xaoxuu/friends-rss-generator # 你的朋友圈数据文件地址
type: fcircle
limit: # 可通过这个限制最大数量

这个功能在 1.18.0 版本后开始支持:

blog/source/_data/widgets.yml
1
2
3
4
5
6
weibo:
layout: timeline
title: 微博动态
api: https://raw.githubusercontent.com/GitHub用户名/仓库名/output/output/tweets.json # 你的微博爬取数据文件地址
type: weibo
limit: 20

无论是哪种动态数据,你都可以在 _config.stellar.yml 中的 site_tree 中设置引用

blog/_config.stellar.yml
1
2
3
site_tree:
...:
leftbar: welcome, recent, 朋友圈, weibo

或者在你需要显示的页面引入,页面内引入优先于配置文件引入:

blog/source/_posts/xxx.md
1
2
3
---
leftbar: [ghuser, 朋友圈]
---

配置默认布局

1.26.0 版本中,站点主结构树有较大的变化,支持自定义每种页面的组件显示情况,侧边栏会按照指定的顺序从组件库中读取组件并显示:

列表类页面

列表类页面是指博客文章列表、专栏列表、wiki 项目列表等页面的配置。

这里解释一下 base_dir 是什么意思,比如说当我创建一个 wiki 项目或者笔记页面时,会自动生成一个总项目列表,该页面的默认路径是 /wiki ,你可以 点此查看 该页面,改变 base_dir 即改变该路径。

blog/_config.stellar.yml
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
# 站点主结构树
site_tree:
# -- 列表类页面 -- #
# 主页配置
home:
leftbar: welcome, recent
rightbar: timeline
# 博客列表页配置
index_blog:
base_dir: blog # 只影响自动生成的页面路径
menu_id: post # 未在 front-matter 中指定 menu_id 时,layout 为 post 的页面默认使用这里配置的 menu_id
leftbar: welcome, recent # for categories/tags/archives
rightbar: timeline
nav_tabs: # 近期发布 分类 标签 专栏 归档 and ...
# '朋友文章': /friends/rss/
# 博客专栏列表页配置
index_topic:
base_dir: topic # 只影响自动生成的页面路径
menu_id: post # 未在 front-matter 中指定 menu_id 时,layout 为 topic 的页面默认使用这里配置的 menu_id
# 文档列表页配置
index_wiki:
base_dir: wiki # 只影响自动生成的页面路径
menu_id: wiki # 未在 front-matter 中指定 menu_id 时,layout 为 wiki 的页面默认使用这里配置的 menu_id
leftbar: ghissues, related, recent # for wiki
rightbar: timeline
nav_tabs:
# 'more': https://github.com/xaoxuu

内容类页面

是指具体到文章页面,文档页面和专栏文章等的具体配置

blog/_config.stellar.yml
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
# 站点主结构树
site_tree:
# -- 内容类页面 -- #
# 博客文章内页配置
post:
menu_id: post # 未在 front-matter 中指定 menu_id 时,layout 为 post 的页面默认使用这里配置的 menu_id
leftbar: related, ghrepo, ghissues, recent # for pages using 'layout:post'
rightbar: ghrepo, toc
# 博客专栏文章内页配置
topic:
menu_id: post
# 文档内页配置
wiki:
menu_id: wiki # 未在 front-matter 中指定 menu_id 时,layout 为 wiki 的页面默认使用这里配置的 menu_id
leftbar: tree, ghissues, related, recent # for wiki
rightbar: ghrepo, toc
# 作者信息配置
author:
base_dir: author # 只影响自动生成的页面路径
menu_id: post
leftbar: recent, timeline
rightbar: timeline
# 错误页配置
error_page:
menu_id: post
'404': '/404.html'
leftbar: recent, timeline
rightbar: timeline
# 其它自定义页面配置 layout: page
page:
leftbar: recent
rightbar: toc, timeline

灵活用法

继承(覆盖)组件

适合有多个相似组件的情况,例如有多个时间线组件,显示规则相同,仅 api 地址不同:

blog/source/_data/widgets.yml
1
2
3
4
5
6
my_timeline_lite:
layout: timeline
title: 近期动态
user: xaoxuu
hide: title,footer
api:

在不同的页面设置不同的 api 地址:

blog/source/_posts/xxx.md
1
2
3
4
5
6
7
---
title: 某一篇文章
leftbar:
- welcome # 只写一个字符串代表引用对应的通用组件
- override: my_timeline_lite
api: https://xxx
---

匿名组件:仅在使用时创建

适合仅在一个页面或项目中才需要用到的组件,例如在某个页面的侧边栏放一个公告:

blog/source/_posts/xxx.md
1
2
3
4
5
6
7
8
9
10
11
12
13
14
---
title: 某一篇文章
leftbar:
- welcome # 只写一个字符串代表引用对应的通用组件
- layout: markdown
title: '重要通知 [NOTE.2022-09]'
content: |
请不要原封不动的把本站内容复制到贵站中使用,这样一方面不尊重原作者,另一方面也会因为存在大量重复内容影响贵站收录甚至降权。

从2022年9月起本站已不再开源,已经持有源码副本或`fork`的朋友请及时删除以防止被他人恶意搬运的情况继续发生。

[> 了解详情](https://github.com/xaoxuu/xaoxuu.github.io#readme)
src: # 可以设置外部 md 文件链接
---

又或者在项目的配置文件中创建专属于这个项目的组件:

blog/_data/projects.yml
1
2
3
4
5
6
7
8
9
10
Stellar:
name: Stellar
title: Stellar - 每个人的独立博客
subtitle: '每个人的独立博客 | Designed by xaoxuu'
leftbar:
- layout: timeline
title: 最近更新
api: https://api.github.com/repos/xaoxuu/hexo-theme-stellar/releases?per_page=1
hide: footer
...