【vuepress】自動生成側(cè)邊欄

如何用vuepress的默認(rèn)主題自動生成側(cè)邊欄

前言

最近在幫公司弄一個(gè)組件庫,所以想著寫一個(gè)文檔伍伤,于是就想到了用vuepress來寫乳蛾,vuepress界面簡潔,基于vue够委,上手比較容易荐类,而且還支持在md里面寫vue語法。

開始

由于官網(wǎng)文檔里面寫的都是怎么生成側(cè)邊欄茁帽,必須將每個(gè)文檔的路由進(jìn)行配置玉罐,沒有寫怎么自動生成側(cè)邊欄,這樣一來文檔一多的話就很麻煩了潘拨,網(wǎng)上試了很多方法都不行厌小,最后找了這位同學(xué)淺墨散人的方法

1文件結(jié)構(gòu)

目錄結(jié)構(gòu)

這里要注意一下 aboutblog 里的文件夾是要在導(dǎo)航欄里配置的,每個(gè)路由下一個(gè)要有 index.md 文件战秋,不然后面會報(bào)錯(cuò)璧亚,導(dǎo)航欄配置官網(wǎng)有介紹這里就不說明了,具體請看導(dǎo)航欄配置

1. 新建遍歷方法 initPage.js

const fs = require('fs');
// 排除檢查的文件
var excludes = ['.DS_Store']

var filehelper = {
    getFileName:function(rpath) {
        let filenames = [];
        // let fileImg = /\.(png|jpe?g|gif|webp)(\?.*)?$/;
        let fileTypes = /\.md$/; //只匹配以md結(jié)尾的文件
        fs.readdirSync(rpath).forEach(file => {
            if (excludes.indexOf(file) < 0 ) {
                fullpath = rpath+"/"+file
                var fileinfo = fs.statSync(fullpath)
                if(fileinfo.isFile()){
                    // if(file.indexOf('.md') > 0) {
                    if(fileTypes.test(file) > 0) {
                        if (file === 'index.md') {
                            file = '';
                        } else {
                            file = file.replace('.md', '');
                        }
                        filenames.push(file);
                    }
                }
            }
        })
        // console.log(filenames)
        filenames.sort(); // 排序
        return filenames;
    }
}
module.exports = filehelper;

這里我稍微修改了下脂信,原本只是判斷 index.md 跟其它文件癣蟋,當(dāng)我在其中一個(gè)目錄里新建圖片文件夾的時(shí)候就出問題了,它把圖片也一起遍歷進(jìn)去了狰闪,導(dǎo)致最后編譯出錯(cuò)疯搅。
所以這里我加多了一個(gè)正則判斷,能正常顯示了但是發(fā)現(xiàn)每個(gè)分類下的側(cè)欄只顯示出來一個(gè)埋泵,檢查發(fā)現(xiàn)是我正則寫成了 /\.md$/gi 幔欧,全文查找,所以只匹配最后一個(gè)滿足條件的丽声,改成這樣 /\.md$/ 就沒問題了礁蔗。
還有一個(gè)方法是用 indexOf() 判斷文件名是否含有 .md ,簡單粗暴。

2. 新建 index.js 文件

index.js 主要是接收參數(shù)雁社,將參數(shù)轉(zhuǎn)換成對象格式浴井,方便在 config.js 里使用

const utils = {
  genSidebar: function (title, children = [''], collapsable = true, sidebarDepth = 2) {
    var arr = new Array();
    arr.push({
      title,
      children,
      collapsable,
      sidebarDepth
    })
    return arr;
  }
};

module.exports = utils;

3. config.js 里使用


const path = require("path")
const rootpath = path.dirname(__dirname) //執(zhí)行一次dirname將目錄定位到docs目錄
const utils = require('./utils/index.js');
const filehelper = require('./utils/initPage.js');

module.exports = {
  //...其它配置

  themeConfig: {
    sidebar: {
      '/blog/css/': utils.genSidebar('css', filehelper.getFileName(rootpath+"/blog/css/"), false),
      '/blog/javascript/': utils.genSidebar('頁面js相關(guān)', filehelper.getFileName(rootpath+"/blog/javascript/"), false),
      '/blog/html/': utils.genSidebar('頁面html相關(guān)', filehelper.getFileName(rootpath+"/blog/html/"), false),
      '/blog/plugins/': utils.genSidebar('插件', filehelper.getFileName(rootpath+"/blog/plugins/"), false),
      '/blog/ui/': utils.genSidebar('組件', filehelper.getFileName(rootpath+"/blog/ui/"), false),
      '/about/': utils.genSidebar('關(guān)于', filehelper.getFileName(rootpath+"/about/"), false),
    }, // 側(cè)邊欄配置
  },
}

上面是根據(jù)我項(xiàng)目結(jié)構(gòu)來配置的,實(shí)際情況根據(jù)你的目錄結(jié)構(gòu)來配置霉撵。

總結(jié)

vuepress使用起來還是比較方便的磺浙,不僅可以用來寫文檔洪囤,還可以用來寫博客,我自己也搭了一個(gè)博客放在github上撕氧,平常有一些想法或總結(jié)就可以在上面分享了瘤缩。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市伦泥,隨后出現(xiàn)的幾起案子款咖,更是在濱河造成了極大的恐慌,老刑警劉巖奄喂,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件铐殃,死亡現(xiàn)場離奇詭異,居然都是意外死亡跨新,警方通過查閱死者的電腦和手機(jī)富腊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來域帐,“玉大人赘被,你說我怎么就攤上這事⌒ごВ” “怎么了民假?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長龙优。 經(jīng)常有香客問我羊异,道長,這世上最難降的妖魔是什么彤断? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任野舶,我火速辦了婚禮,結(jié)果婚禮上宰衙,老公的妹妹穿的比我還像新娘平道。我一直安慰自己,他們只是感情好供炼,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布一屋。 她就那樣靜靜地躺著,像睡著了一般袋哼。 火紅的嫁衣襯著肌膚如雪冀墨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天先嬉,我揣著相機(jī)與錄音轧苫,去河邊找鬼。 笑死疫蔓,一個(gè)胖子當(dāng)著我的面吹牛含懊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播衅胀,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼岔乔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了滚躯?” 一聲冷哼從身側(cè)響起雏门,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎掸掏,沒想到半個(gè)月后茁影,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丧凤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年募闲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片愿待。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡浩螺,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出仍侥,到底是詐尸還是另有隱情要出,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布农渊,位于F島的核電站患蹂,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏砸紊。R本人自食惡果不足惜况脆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望批糟。 院中可真熱鬧格了,春花似錦、人聲如沸徽鼎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽否淤。三九已至悄但,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間石抡,已是汗流浹背檐嚣。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留啰扛,地道東北人嚎京。 一個(gè)月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓嗡贺,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鞍帝。 傳聞我的和親對象是個(gè)殘疾皇子诫睬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

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