参考文档: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 侧边栏自动生成
猜你喜欢
- vue keep-alive 2023-10-08
- ajax实现输入提示效果 2023-02-14
- JS实现左侧菜单工具栏 2022-08-31
- javascript 判断当前浏览器版本并判断ie版本 2023-08-08
- 深入浅析AjaxFileUpload实现单个文件的 Ajax 文件上传库 2022-12-15
- 关于 html:如何从 css 表中删除边距和填充 2022-09-21
- layui数据表格以及传数据方式 2022-12-13
- 基于CORS实现WebApi Ajax 跨域请求解决方法 2023-02-14
- 1 Vue - 简介 2023-10-08
- jsPlumb+vue创建字段映射关系 2023-10-08