hexo-next-主題構(gòu)建首頁動態(tài)更新目錄

1 問題及需求

問題

  • 首頁(home)默認顯示按日期排序的文章列表佳簸,使用 `` 省略內(nèi)容仍顯得繁雜冗長遣鼓;
  • 分類(categories)頁面雖然有按類型、日期排序的文章列表,但切換分類需要往返多次蛙粘。

需求

  • 建立一個首頁目錄,將文章分類(categories 參數(shù))和標題但壮,分別作為列表的一級么库、二級顯示;
  • 標題即為文章鏈接久橙,點擊可直接到達俄占;想查看其他分類,直接回到首頁即可淆衷。

2 解決方案

2.1 建立文件

source/ 下建立 index.md缸榄,命名標題,內(nèi)容留空祝拯。

2.2 關(guān)閉默認首頁

修改 hexo 配置文件 _config.yml甚带,找到 index_generator 配置項,修改 path 屬性為一個無效值:

index_generator:
  path: 'xxxx'
  per_page: 10
  order_by: -date

此時啟動項目后佳头,首頁將不再出現(xiàn)文章列表鹰贵,轉(zhuǎn)而顯示 index.md 內(nèi)容。

注:index.md 在渲染后成為 index.html

3 動態(tài)更新目錄

若文章分類多康嘉,每次更新碉输、調(diào)整文章都需要將相應(yīng)鏈接手工同步到首頁也是一件相當繁瑣的事情。因此有必要考慮自動更新首頁亭珍。

3.1 hexo 加載順序

根據(jù) hexo 文檔 https://hexo.io/zh-cn/api/posts#%E6%B8%B2%E6%9F%93 關(guān)于渲染順序的說明敷钾,要實現(xiàn) index.md 的寫入,要在 hexo g 命令執(zhí)行之前完成肄梨,可引入 before_post_render 過濾器實現(xiàn)該需求阻荒。

3.2 hexo 過濾器

過濾器文檔:https://hexo.io/zh-cn/api/filter#%E6%A6%82%E8%A6%81

在主題目錄下 themes\next\filters\ 新建 index.js,添加 priority 分別為 9 和 10 的兩個 before_post_render 過濾器众羡,如下所示:

'use strict'

const categoriesMap = new Map();

hexo.extend.filter.register('before_post_render', data => {

    // 首頁目錄不顯示草稿內(nèi)容
    if (data.source.indexOf("_drafts") >= 0) {
        return data;
    }

    if (data.path.indexOf("index") < 0 && data.categories.length > 0) {

        let curCategorie = data.categories.data[0].name;

        if (categoriesMap.has(curCategorie)) {
            let valueArray = categoriesMap.get(curCategorie);
            valueArray = valueArray.concat(`  - [${data.title}](/${data.path})\n`)
            categoriesMap.set(curCategorie, valueArray);
        } else {
            categoriesMap.set(curCategorie, [`  - [${data.title}](/${data.path})\n`]);
        }
    }
    return data;
}, 9);

hexo.extend.filter.register('before_post_render', data => {
    // 精確定位index.html侨赡,防止誤寫其他路徑不同但同名的文件
    if (data.path.indexOf("index") === 0) {

        for (let key of categoriesMap.keys()) {
            data.content += `- ${key}\n`
            let valueArray = categoriesMap.get(key);
            valueArray.forEach(element => {
                data.content += element;
            });
        }
        return data;
    }
    return data;
}, 10);

代碼說明

  • 第一個過濾器遍歷全部文章,獲取所有現(xiàn)存的分類及所屬文章鏈接;
  • 第二個過濾器寫入 index.html

3.3 有關(guān)屬性

為探究 data 為何物羊壹,可打斷點觀察其結(jié)構(gòu):

{
  title: "DataGrip-2018.3.4-數(shù)據(jù)導出配置案例",
  date: {……文章生成日期的有關(guān)參數(shù)(略)},
  _content: "……正文內(nèi)容(略)",
  source: "_posts/DataGrip-2018-3-4-數(shù)據(jù)導出配置案例.md",
  raw: "……正文內(nèi)容(略)",
  slug: "DataGrip-2018-3-4-數(shù)據(jù)導出配置案例",
  published: true,
  updated: {……文章更新日期的有關(guān)參數(shù)(略)},
  comments: true,
  layout: "post",
  photos: [
  ],
  link: "",
  _id: "cljzhnjmb001oz0u6en5ab6xb",
  path: "2022/12/07/DataGrip-2018-3-4-數(shù)據(jù)導出配置案例/",
  permalink: "http://www.dcheng.site/2022/12/07/DataGrip-2018-3-4-%E6%95%B0%E6%8D%AE%E5%AF%BC%E5%87%BA%E9%85%8D%E7%BD%AE%E6%A1%88%E4%BE%8B/",
  full_source: "C:\\mainProjects\\blog\\source\\_posts\\DataGrip-2018-3-4-數(shù)據(jù)導出配置案例.md",
  asset_dir: "C:\\mainProjects\\blog\\source\\_posts\\DataGrip-2018-3-4-數(shù)據(jù)導出配置案例\\",
  tags: {
    data: [
      {
        name: "DataGrip",
        _id: "cljzhnjmc001uz0u6hlov172o",
        slug: "DataGrip",
        path: "tags/DataGrip/",
        permalink: "http://www.dcheng.site/tags/DataGrip/",
        posts: {
          data: [
          ],
          length: 0,
        },
        length: 0,
      },
    ],
    length: 1,
  },
  categories: {
    data: [
      {
        name: "配置案例",
        _id: "cljzhnjmc001tz0u6967u3bji",
        slug: "配置案例",
        path: "categories/配置案例/",
        permalink: "http://www.dcheng.site/categories/%E9%85%8D%E7%BD%AE%E6%A1%88%E4%BE%8B/",
        posts: {
          data: [
          ],
          length: 0,
        },
        length: 0,
      },
    ],
    length: 1,
  },
  content: "……正文內(nèi)容(略)",
  site: {
    data: {
    },
  },
}

4 最終效果

圖1-默認效果.png
圖2-動態(tài)目錄效果.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蓖宦,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子舶掖,更是在濱河造成了極大的恐慌球昨,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眨攘,死亡現(xiàn)場離奇詭異主慰,居然都是意外死亡,警方通過查閱死者的電腦和手機鲫售,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門共螺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人情竹,你說我怎么就攤上這事藐不。” “怎么了秦效?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵雏蛮,是天一觀的道長。 經(jīng)常有香客問我阱州,道長挑秉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任苔货,我火速辦了婚禮犀概,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘夜惭。我一直安慰自己姻灶,他們只是感情好,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布诈茧。 她就那樣靜靜地躺著产喉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪敢会。 梳的紋絲不亂的頭發(fā)上镊叁,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機與錄音走触,去河邊找鬼。 笑死疤苹,一個胖子當著我的面吹牛互广,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼惫皱,長吁一口氣:“原來是場噩夢啊……” “哼像樊!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起旅敷,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤生棍,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后媳谁,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體涂滴,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年晴音,在試婚紗的時候發(fā)現(xiàn)自己被綠了柔纵。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡锤躁,死狀恐怖搁料,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情系羞,我是刑警寧澤郭计,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站椒振,受9級特大地震影響昭伸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜杠人,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一勋乾、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嗡善,春花似錦辑莫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至袁铐,卻和暖如春揭蜒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背剔桨。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工屉更, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人洒缀。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓瑰谜,卻偏偏與公主長得像欺冀,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子萨脑,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容