基于目录为VitePress生成侧边栏

3,100 阅读2分钟

今天封装了一个用于自动生成VitePress 侧边栏的npm包,分享一下,求求帮忙Star

github

vitepress-plugin-autobar

这应该是目前最简洁好用的生成VitePress 侧边栏的工具了。

VitePress

VitePress 是基于 Vite构建的文档网站框架,是 VuePress 的升级版本。

Vue3的文档就是用VitePress搭建的。

安装

npm install -D vitepress-plugin-autobar

使用

import { getSideBar } from 'vitepress-plugin-autobar'

module.exports = {
  // ...
  themeConfig: {
    // ...
    sidebar: getSideBar("./docs"),
  },
};

How it work?

如果你的目录是下面这样的。

.
├─ docs
│  ├─ .vitepress
│  │  └─ config.js
│  ├─ 01.Introduction
│  │  └─ START.md
│  ├─ 02.Utils
│  │  └─ dateUtil.md
│  │  └─ storeUtil.md
│  └─ index.md

调用 getSideBar 会生成下面这样的侧边栏数据。

文件的编号会被用于排序,并被自动去除。

[
    {
        "text":"Introduction",
        "items":[
            {
                "text":"START",
                "link":"01.Introduction/START"
            }
        ]
    },
    {
        "text":"Utils",
        "items":[
            {
                "text":"dateUtil",
                "link":"02.Utils/dateUtil"
            },
            {
                "text":"storeUtil",
                "link":"02.Utils/storeUtil"
            }
        ]
    },
    {
        "text":"Index",
        "items":[
            {
                "text":"Index",
                "link":"index"
            }
        ]
    }
]

VitePress的侧边栏配置

下一步计划

如果未来VitePress支持插件,将通过插件的形式,提供自动生成侧边栏的支持。

如果你有其他需求,欢迎提issus,合理的一定会实现。

实现过程

实现过程比较简单,这里只简单贴一下流程就可以了。

  • 新建npm包
  • 添加TypeScript支持
  • 添加ESLint(Quality
  • 代码实现:简单的遍历目录,按vitepress的配置结构生成sidebar数据。
  • 添加rollup打包配置
  • 添加Jest测试(Quality
  • 补充文档(Quality
  • npm包发布

后面带Quality的流程,都是影响npm质量评分的项目,不要偷懒不做。

参考资料

vuepress-plugin-autobar

制作一个同时支持 ESM, CJS, Browser 的 Package

往期好文

koa入门系列

【koa快速入门】之基础使用

【koa快速入门】之最佳实践

【koa快速入门】之深究原理

“告别烂代码”

2022代码规范最佳实践(附web和小程序最优配置示例)

【前端探索】告别烂代码!用责任链模式封装网络请求

【前端探索】告别烂代码第二期!用策略模式封装分享组件

代码人生

【三年前端开发的思考】如何有效地阅读需求?

前端踩坑必看指南

中杯超大杯中间的新选择——vue2.7+vite+ts实践

Node.js脚手架开发完全指南「TypeScript版」

【前端探索】图片加载优化的最佳实践

【前端探索】移动端H5生成截图海报的探索

【前端探索】H5获取用户定位?看这一篇就够了

【前端探索】微信小程序跳转的探索——开放标签为什么存在?

【前端探索】vConsole花式用法