沃梦达 / IT编程 / 前端开发 / 正文

vuepress 侧边栏自动生成

参考文档:Node.js 中 __dirname 和 ./ 的区别https://github.com/Darcrandex/my-blogVuePress 自动生成侧边栏和导航栏,完美替代 GitBook1.第一种方法,安装插件vuepress-plugin-autobar:?boboidream/vuepr...

参考文档:

Node.js 中 __dirname 和 ./ 的区别

https://github.com/Darcrandex/my-blog

VuePress 自动生成侧边栏和导航栏,完美替代 GitBook

1.第一种方法,安装插件

"vuepress-plugin-autobar":?"boboidream/vuepress-bar",

可以自动生成侧边栏,但侧边栏分组的展开关闭是互斥的

 

2.第二种方法,获取文件夹下结构自行处理

安装插件:

"directory-tree": "^2.2.7",

使用:

 sidebar: autoGetSidebarOptionBySrcDir(path.resolve(__dirname, "../notes")),

我的目录结构:

 

 获取到的数据:

 数据处理:

const path = require("path");
const dirTree = require("directory-tree");
const SRC_PATH = path.resolve(__dirname, "../src");

// 按照 vuepress '分组侧边栏'的规范生成单个配置
// https://vuepress.vuejs.org/zh/theme/default-theme-config.html#%E4%BE%A7%E8%BE%B9%E6%A0%8F%E5%88%86%E7%BB%84
function toSidebarOption(tree = []) {
    if (!Array.isArray(tree)) return [];

    return tree.map((v) => {
        if (v.type === "directory") {
            return {
                title: (v.name).split('-')[1],
                collapsable: false, // 可选的, 默认值是 true,
                sidebarDepth: 1,
                children: toSidebarOption(v.children),
            };
        } else {
            // 因为所有的md文件必须放到'docs'文件夹下
            // 所以相对路径就是'docs'后面的部分
            // 最后把扩展名去掉, 就是路由的路径
            return v.path.split("docs")[1].replace(/\.md$/, "");
        }
    });
}

/**
 * @desc 根据 自定义文件夹'docs/src'自动生成vuepress的sidebar选项
 * @param {string} srcPath 自定义文件夹路径,必须在docs文件夹下
 * @returns {object[]}
 */
function autoGetSidebarOptionBySrcDir(srcPath = SRC_PATH) {
    const srcDir = dirTree(srcPath, {
        extensions: /\.md$/,
        normalizePath: true,
    });
    const ress = toSidebarOption(srcDir.children)
    return toSidebarOption(srcDir.children);
    // [title:'group-name', children:['/route-a','route-b']]
}

module.exports = autoGetSidebarOptionBySrcDir;

 

 

 

本文标题为:vuepress 侧边栏自动生成