適用於 >= 3.5.0

側邊欄現在支持自定義了,可以添加自己喜歡的 widget。

可添加自己的 widget,也可以對現有的 widget 進行排序(由於 widget 過多,會導致 TOC 過早滾動,因此添加的 widget 只會出現在 page 頁。排序只對 sticky_layout 裏的有效,也就是博客資料公告這兩個固定,其它的能排序)

widget 排序

只需要配置 sort_order就行。(使用了 Flex 佈局的 order 屬性,具體可查看 mozilla 文檔。簡單來講,就是配置數字來實現排序,如果不配置,則默認為 0。數字越小,排序越靠前。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
aside:
...
card_recent_post:
sort_order: # Don't modify the setting unless you know how it works
card_categories:
sort_order: # Don't modify the setting unless you know how it works
card_tags:
sort_order: # Don't modify the setting unless you know how it works
card_archives:
sort_order: # Don't modify the setting unless you know how it works
card_webinfo:
sort_order: # Don't modify the setting unless you know how it works

newest_comments:
enable: true
sort_order: # Don't modify the setting unless you know how it works

自定義 widget

如果你想添加自己的內容到側邊欄去,你可以自定義。

創建 widget.yml

在Hexo博客目錄中的source/_data(如果沒有 _data 文件夾,請自行創建),創建一個文件 widget.yml

格式

1
2
3
4
5
6
7
8
9
10
11
12
- class_name:
id_name:
name:
icon:
order:
html:
- class_name:
id_name:
name:
icon:
order:
html:

參數詳解

參數 解釋
class_name 所創建的 widget 父類 class 名 (可選)
id_name 所創建的 widget 父類 id 名(可選)
name 所創建的 widget 標題
icon 所創建的 widget 圖標
order 所創建的 widget 排序 (可選)
html 所創建的 widget 相關代碼

image-20201230223506507

生成的 代碼 為

1
2
3
4
5
6
7
8
9
<div class="card-widget 所寫的 class_name" id="所寫的 id_name" style="order: 所寫的 order">
<div class="item-headline">
<i class="所寫的 icon"></i>
<span>所寫的 name</span>
</div>
<div class="item-content">
所寫的 html
</div>
</div>

如果你需要對添加的 widget 進行 UI 調整,請自行添加 css 到 inject 去。

例子

訪客地圖 為例子

  1. 獲取訪客地圖的 html 代碼

    1
    <script type="text/javascript" id="clstr_globe" src="//clustrmaps.com/globe.js?d=5V2tOKp8qAdRM-i8eu7ETTO9ugt5uKbbG-U7Yj8uMl8"></script>
  2. 創建 widget.yml

    1
    2
    3
    4
    5
    6
    - class_name: user-map
    id_name: user-map
    name: 訪客地圖
    icon: fas fa-heartbeat
    order:
    html: '<script type="text/javascript" id="clstr_globe" src="//clustrmaps.com/globe.js?d=5V2tOKp8qAdRM-i8eu7ETTO9ugt5uKbbG-U7Yj8uMl8"></script>'
  3. 運行 hexo

    image-20201230224442356