1.4 组件封装和文档编写
书接上文。项目经过一系列的配置,开发脚手架已经搭建完毕。接下来开始封装自定义组件、并基于 markdown 文件生成文档和演示案例。
后续文章代码会根据篇幅,不影响理解的情况下进行部分删减,详细代码可在 Github Repo 查看。
封装第一个组件
封装组件
接下来封装一个loading组件。
创建 packages/loading/src/main.vue 文件(篇幅问题,样式代码详见Github)。
<template>
<div class="me-loading">
<div class="loader">
<div class="loader-inner">
<div class="loader-line-wrap">
<div class="loader-line"></div>
</div>
<div class="loader-line-wrap">
<div class="loader-line"></div>
</div>
<div class="loader-line-wrap">
<div class="loader-line"></div>
</div>
<div class="loader-line-wrap">
<div class="loader-line"></div>
</div>
<div class="loader-line-wrap">
<div class="loader-line"></div>
</div>
</div>
</div>
<div class="loading-text">{{ loadingText }}</div>
</div>
</template>
<script>
export default {
name: 'MeLoading',
props: {
loadingText: {
type: String,
default: '',
},
},
};
</script> 创建 packages/loading/index.js 文件。使用 install 方法来全局注册该组件,安装组件通过全局方法 Vue.use() 即可。官网-Vue插件
创建 src/index.js 文件,该文件的作用:
导入组件库所有组件
定义组件库组件注册安装的install 方法
整体导出版本、install、各个组件等。
引用组件
在 examples/main.js 文件中引用组件库
在 examples/App.vue 中添加组件引用
页面效果如下
编写组件说明文档
接下来基于 markdown 编写组件文档,能让示例代码像组件一样在页面中渲染。
md-loader
markdown 文件的解析基于markdown-it 及其社区插件。
markdown-it主要的解析器/渲染器。官方文档markdown-it-anchor生成标题锚点。官方文档markdown-it-container创建块级自定义容器的解析插件。官方文档markdown-it-chain支持链式调用 markdown-it 。官方文档
其他核心插件
自定义loader 项目将使用element的自定义loader,在源码目录 build\md-loader 创建文件,目录结构如下。
index.js文件是loader的入口文件,通过提取template 与 script 的内容,把 Markdown 转化成 Vue 组件。
config.js文件使用 markdown-it-chain 配置markdown-it选项、插件和容器信息,初始化markdown-it实例。
containers.js文件使用 markdown-it-container 来转换自定义容器,将自定义容器 :::demo转换成 demo-block 组件。
fence.js文件中重写了代码块(fence)默认渲染规则。
util.js文件提供 stripScript stripStyle stripTemplate genInlineComponentText等方法用于页面内容提取和生成组件。
webpack 配置
创建build/config.js文件设置 webpack 公共配置信息。
更新 build\webpack.config.js文件,添加自定义 md-loder ,实现 markdown 文件的解析。
编写文档
编写组件说明文档examples\docs\loading.md
安装 vue-router 插件。
新增 examples/router.js 文件配置路由信息。
调整 examples 目录下文档结构如下,详见源码。
examples\main.js 引入路由,examples\App.vue 更新路由导航信息。
页面效果如下
demo-block 组件
上面的说明文档功能十分简陋,接下来编写 demo-block 组件,支持示例组件渲染、高亮代码等功能。
安装语法高亮插件 highlight.js 。
创建 examples\components\demo-block.vue 组件
examples\main.js 引入 highlight 插件、 demo-block 组件,配置语法高亮主题样式。增加 afterEach 全局后置钩子,高亮页面代码块。
组件说明文档 examples\docs\loading.md 更新成约定的文档格式。
运行程序,页面示例代码块渲染组件,可以展开收起源代码,语法高亮显示,效果如下:
References
Element 文档中的 Markdown 解析 element的demo-block highlight 97种主题样式列表
最后更新于