前端组件库文档解决方案

本篇主要分享什么内容:

  • 常用的文档/静态站点生成工具有哪些
  • 每个工具有什么特点
  • 工具适应场景

前置概念

组件库文档工具选型

AndD组件库文档是怎么制做的,使用了什么工具。

以AntD Button组件为例,我们看一下antd组件库的文档页面结构构成和文档生成:

Button文档

Button文档仓库源文件

网站文档仓库源文件

按钮类型

bisheng

AntD使用了bisheng来生成组件库文档,把MarkDown进行拼接和渲染成最终的文档展示页面。

静态站生成工具方案

  1. vuePress
  1. gitbook
  1. MDX

    MarkDown + JSX

    支持导入React组件

    支持remark 生态系统中的任何插件

    Playground 实时修改,实时预览

    基础

    支持MarkDown语法

    完全支持JSX 以<字符开头的行都视为JSX代码块

    支持import 和 exports

    import 组件 json数据 md或mdx文档

    MDXProvider

    提供MarkDown渲染HTML使用组件的映射 组件列表

  1. Gatsby

    Demo

    1. 初始化

      npm init gatsby
      
      npm install -g gatsby-cli
      gatsby new
      
    2. 运行

      npm run develop
      
    3. 特点:生态好,功能丰富,有各种各样的插件,支持MDX。

      Gatsby 有一个强大的功能,称为数据层,使用 Gatsby 的数据层,您可以组合来自多个来源的数据,这让您可以为每种类型的数据选择最佳平台。

      [图片上传失败...(image-3176be-1649995078232)]

      http://localhost:8000/___graphql中可以看到GraphQL数据

    4. 数据来源
      Gatsby-source-*

      数据拉入:页面数据拉入 使用页面查询,页面中导出 query,通过graphql查询即可

                    组件中拉入数据  可以使用useStaticQuery钩子拉入,
      
    5. 动态创建页面

      Gatsby的 文件系统路由 API定义用于命名src/pages目录中文件的特殊语法,它允许您根据数据层中的节点集合为站点动态创建新页面。

  1. JSDoc

    根据javascript文件中注释信息,生成JavaScript应用程序或库、模块的API文档 的工具

    安装

    npm install -D jsdoc
    

    使用

    jsdoc  xxx.js
    

    默认会输出文档到out文件夹,可以通过--destination指定输出路径

    jsdoc-to-markdown

  1. TSDoc

    https://tsdoc.org/play

  1. React Styleguidist
  1. StoryBook

    一个强大的集组件开发,查看,测试的文档工具,支持多种框架。使用”组件驱动开发“理念。

    • 支持多种框架 React Vue Angular Ember Preact Svelte等

    Tutorials

    CDD

  1. docsify

    特点:

    • 简单轻便
    • 没有静态构建的 html 文件
    • 多个主题

    安装

    npm i docsify-cli -g
    

    初始化

    docsify init ./docs
    

    预览

    docsify serve docs
    

    目录结构

    index.html 文件入口

    README.md 主页

    .nojekyll 防止GitHub Pages忽略以下划线开头的文件

    侧边栏

    创建 _sidebar.md(支持目录层级嵌套)。

    _sidebar.md中页面会自动生成标题和子标题

    自定义导航栏

    • html标签
    • _navbar.md(同样支持目录层级嵌套,展示形式为弹窗)

    封面

    _coverpage.md #/ 首页全屏展示

    可以指定背景图和背景色

    可以指定只展示封面

    配置

    window.$docsify = {

    el:'#app', // 根元素

    repo:'docsifyjs/docsify/', //Git仓库地址

    maxLevel: 6, // 目录最大层级

    loadNavbar: false, // 加载_navbar.md作为导航栏(或者直接指定md路径)

    loadSidebar: false, // 加载_sidebar.md作为侧边栏

    hideSidebar: true, // 隐藏侧边栏

    subMaxLevel: 0, // 在自定义侧边栏中添加目录(最大层级)

    auto2top: true, // 页面路径改变时滚动到屏幕顶部

    homepage: 'README.md', // #/ 主页

    basePath: '/path/', // 基本路径, 可以将其设置为其他目录或其他域名

    relativePath: false, // 如果为 true,则链接是相对于当前上下文的。

    coverpage: false, // 封面 默认加载_coverpage.md,也可以指定md路径

    logo,

    name,

    nameLink,

    markdown, // 自定义渲染MarkDown为HTML 文档

    themeColor,

    executeScript: true,

    mergeNavbar: true, // 小屏幕上的导航栏将与侧边栏合并

    externalLinkTarget: '_self', // default: '_blank' 打开默认连接方式

    routerMode: 'history', // default: 'hash' 路由模式

    onlyCover: false, // #/只展示封面

    requestHeaders: { 'x-token': 'xxx', }, // 设置请求资源头

    notFoundPage: true, // 加载_404.md 或指定相应的md

    vueComponents, // 注册vue组件, 可在md中直接使用

    vueGlobalOptions,

    vueMounts

    }

    主题 官方和社区制作的主题

    插件 全文检索,谷歌分析,表情符号,第三方脚本支持,图片缩放,在github上编辑,jsfiddler Demo预览,复制到剪切板,Gitalk, 分页和标签

    PWA

    SSR

    嵌入文件:支持视频, 音频,iframe或代码块,甚至MarkDown

  1. Docz

    • 基于MDX进行了封装
    • 完全使用Gatsby构建,可以使用Gatsby的插件和工具生态
    • 零配置
    • TypeScript支持

    安装

    npm install docz # react react-dom
    

    运行

    "scripts": {
        "docz:dev": "docz dev",
        "docz:build": "docz build",
        "docz:serve": "docz build && docz serve"
    }
    

    开发

    创建.mdx文件即可(指定name和route)。

    构建

    npm run build # 生成静态资源在.docz/dist目录中
    npm run build -- --dest docs-site-directory  # 通过--dest 指定文档生成目录
    

    也可以在配置中指定打包输出目录

    // doczrc.js
    export default {
      dest: '/some-folder'
    }
    

    部署

    构建之后可以使用任何静态站点托管服务进行部署。

    MDX支持

    可以直接引入.jsx/.tsx组件,样式;

    内置组件

    • Playground

      Playground支持编辑实时渲染,支持函数组件和State

    • Props

      组件内的prop-types定义和typeScript的Interface会通过<Props>转换成表格展示

    文档设置

    使用YMAL自定义文档设置(也可以自定义属性,用于自定义theme)

    ---
    name: My Document
    route: /custom-route
    menu: Documents
    hidden: false
    ---
    

    CSS预处理器

    需要Gatsby提供的能力,安装插件

    TypeScript支持

    // doczrc.js
    export default {
      typescript: true
    }
    

    如果需要精确控制组件后缀,可以使用filterComponents and docgenConfig进行过滤

    支持自定义主题

    项目配置

    基本配置

    base 页面访问的basePath

    src 指定组件存放目录

    files 指定docz解析文件查找路径规则 默认会查找所有扩展名为.mdx的文件

    ignore 需要忽略解析的文件

    dest 指定docz build的目录

    title Header展示title,默认会去package.json中name字段

    description HTML中meta字段

    typescript typescript支持 默认false .mdx文件中需要引入TypeScript组件则需要设置

    propsParser props格式化 供<Props />渲染使用,禁用可以提升性能。

    config 指定docz配置文件 默认顺序 docz.json | .doczrc | doczrc.json |doczrc.js | docz.config.js | docz.config.json

    public 指定公共目录,绝对资源路径会从这个目录下取数据

    editBranch 点击 Github 按钮时用于编辑文档的分支

    host devServer地址 默认 '127.0.0.1'

    port devServer 端口

    构建流程

    menu 可指定菜单中文档的顺序

    plugins 指定要使用的插件数组

    组件和HooksAPI

    ComponentsProvider 将组件传递给 MDX,它们将在您将 Markdown 转换为 html 时使用

    Playground 渲染组件并在其中显示代码的可编辑版本

    Props 获取组件并根据组件中属性定义生成属性表的组件

    useComponents 配合ComponentsProvider使用

    useDocs 获取所有已解析文档的列表, 当要创建菜单或列表之类的内容时会很有用。

    useMenus 返回 Docz 构建的菜单

    useConfig 获取项目配置中项目配置对象

    支持自定义插件和MDX插件

    使用注意:每次涉及到路由的变化都需要重启生效,遇到缓存问题可以删除.docz文件夹后重启

    // 一个简单的docz配置 doczrc.js
    export default {
      files: './docs/mdx/*.{md,markdown,mdx}',
      dest: './docs/site',
      title: 'Flex-Ctrip-Offline',
      typescript: true
    }
    
  1. Dumi

    • 开箱即用
    • 为组件开发而生,支持Markdown扩展,可以渲染组件
    • 主题系统,支持自定义渲染样式
    • API自动生成,基于TypeScript类型定义自动生成组件API

    组件开发脚手架

    npx @umijs/create-dumi-lib   # 初始化一个文档模式的组件库开发脚手架
    npx @umijs/create-dumi-lib --site # 初始化一个站点模式的组件库开发脚手架 (比文档模式多一个主页,主页使用docs/index.md)
    # 也可手动切换文档模式 => 站点模式: 修改.umirc.ts,添加mode:'site'
    

    静态站点脚手架

    npx @umijs/create-dumi-app
    

    运行

    npm install 
    npm start
    

    构建及部署

    npm run build
    

    目录结构

    ├── README.md
    ├── docs  # 组件库文档目录
    │   ├── index.md # 组件库文档首页(不存在会使用README.md)
    │   └── otherDir # 组件文档其他路由
    │           ├── index.md
    │           ├── sample.md
    │           └── help.md
    ├── src   # 组件库源码目录(单纯文档站点可忽略)
    │   ├── Foo
    │   └── index.ts
    ├── .umirc.ts # dumi配置文件
    └── .fatherrc.ts # father-build的配置文件用于组件库打包
    

    代码块

    jsx和tsx的代码块会被dumi解析为React组件,并进行渲染。

    dumi引入组件原则:

    像用户一样使用组件:直接引入组件库进行文档demo演示。不仅可以用来调试组件、编写文档,还能用来被用户直接拷贝到项目中使用。dumi会为我们自动创建组件库NPM包->组件库源代码的映射。
    

    外部demo

    可以引入外部文件作为demo渲染,并可支持查看demo源代码

    <code src="/path/to/complex-demo.tsx"></code>
    

    直接嵌入渲染

    ```jsx
    /**
     * inline: true
     */
    import React from 'react';
    export default () => '我会被直接嵌入';
    ```
    

    embed Markdow嵌套

    <!-- 引入全量的 Markdown 文件内容 -->
    <embed src="/path/to/some.md"></embed>
    <!-- 根据行号引入指定行的 Markdown 文件内容 -->
    <embed src="/path/to/some.md#L1"></embed>
    <!-- 根据行号引入部分 Markdown 文件内容 -->
    <embed src="/path/to/some.md#L1-L10"></embed>
    <!-- 根据正则引入部分 Markdown 文件内容 -->
    <embed src="/path/to/some.md#RE-/^[^\r\n]+/"></embed>
    

    组件API自动生成

    JS Doc注释 + TypeScript类型定义的方式实现组件API自动生成

    如何在非-umi-项目中使用-dumi

    DEMO理念

目前我们选择的是使用Docz来做为业务组件库的文档生成工具,下一篇会讲一下我们为什么选择Docz,它有什么优点。欢迎持续关注,微信公众号”混沌前端“

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容