实现vitepress自动生成vue3组件文档

合格的组件文档至少要满足以下条件

  • 要有使用示例
  • 使用示例可预览
  • 可直接查看使用示例的代码且代码可直接复制

vitepress写vue3组件文档的不足之处

未找到一款能自动生成组件文档的插件。虽说,手动编写也不是不行,但容易导致代码变更之后,组件文档与实际代码不统一的问题

一些你可能想到或找过的方案

基于以上几点, 可能只能自行实现了

期望的效果

期望在md文件中,仅编写如下代码,就能自动帮我将MyComp.vue组件的文档生成,并插入到这里

makefile 复制代码
::: VueDoc /src/test/MyComp.vue
:::

需要掌握的前置知识

实现该需求步骤

第一步:实现自定义vite插件

作用

  1. 该插件随vite启动,使用vue-docgen-api读取vue组件的props,events,slots信息,然后自行将这些数据转换为markdown内容,再将markdown内容转化为html内容,然后形成vite的虚拟文件。方便后续自定义vue组件中读取该内容,将其显示到markdown中
  2. 监听vue文件变化,当vue文件变化时,自动重启vite,从而达到重启vitepress的目的

第二步: 实现对markdown-it的扩展

通过 markdown-it-container 实现

作用

将如下标签,解析为自定义vue组件标签, 并将相对路径转为绝对路径

makefile 复制代码
::: VueDoc /src/test/Demo.vue
:::

解析后

ini 复制代码
<MyVueDoc absoluteFilePath="E:/project/test/src/test/Demo.vue"></MyVueDoc>

第三步: 实现这个MyVueDoc组件,并在vitepress中进行全局注册

作用

读取vite的虚拟文件(该虚拟文件有组件的绝对路径以及组件的html文档),然后,通过传入的绝对路径,从虚拟文件中找到对应的组件html文档,然后,将其渲染到界面上

第四步: 慢慢打磨,使其更符合你的需求

你可能的疑惑

为什么要这么多自定义组件配合? 不能在一个地方实现吗?

答:不能在一个地方实现。

原因:

  • 因为需要通过node读取vue源文件,而vue组件中是无法使用node相关能力的
  • markdown-it的扩展可以使用node相关能力,但不接收返回Promise结果,而vue-docgen-api解析结果是一个Promise

成品的大概效果

参考资料

为 vitepress 添加更专业的 Demo 演示能力 - 知乎 (zhihu.com)

vitepress-demo-preview: vitepress中显示vue的demo和源代码的插件 (gitee.com)

相关推荐
熊的猫37 分钟前
JS 中的类型 & 类型判断 & 类型转换
前端·javascript·vue.js·chrome·react.js·前端框架·node.js
mosen8681 小时前
Uniapp去除顶部导航栏-小程序、H5、APP适用
vue.js·微信小程序·小程序·uni-app·uniapp
别拿曾经看以后~2 小时前
【el-form】记一例好用的el-input输入框回车调接口和el-button按钮防重点击
javascript·vue.js·elementui
Gavin_9153 小时前
【JavaScript】模块化开发
前端·javascript·vue.js
Devil枫8 小时前
Vue 3 单元测试与E2E测试
前端·vue.js·单元测试
GIS程序媛—椰子10 小时前
【Vue 全家桶】6、vue-router 路由(更新中)
前端·vue.js
毕业设计制作和分享10 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
程序媛小果11 小时前
基于java+SpringBoot+Vue的旅游管理系统设计与实现
java·vue.js·spring boot
从兄11 小时前
vue 使用docx-preview 预览替换文档内的特定变量
javascript·vue.js·ecmascript
凉辰12 小时前
设计模式 策略模式 场景Vue (技术提升)
vue.js·设计模式·策略模式