Введение
Недавно я начал брать на себя общедоступную библиотеку компонентов пользовательского интерфейса компании, поэтому я подумал о создании документа библиотеки компонентов, похожего на официальный сайт element.
shotCat_doc может помочь вам быстро создать собственную документацию по библиотеке компонентов, основанную на реализации vuepress. Следуя документации element-ui, он реализует отображение компонентов, отображение кода, онлайн-операцию, отображение таблицы API, переключение версий документа, поддержку комментариев и т. д. Он может помочь вам быстро создать прототип документа компонента с нуля, и он уже выполнил всю работу по настройке, которая вам нужна по умолчанию, так что его можно использовать действительно из коробки.
Если вам нравится этот проект добро пожаловатьstar!Или есть какие-либо проблемы с использованием и ошибки, добро пожаловать, чтобы представитьвыпуск и пр
Установить
клонировать проект
git clone https://github.com/1011cat/shotCat_doc.git
Войдите в каталог проекта
cd shotCat_doc
Установить зависимости
npm install
Не рекомендуется использовать cnpm для прямой установки зависимостей, будут всевозможные странные баги. Проблема низкой скорости загрузки npm может быть решена следующими операциями
npm install --registry=https://registry.npm.taobao.org
запустить службу
npm run dev
доступ через браузерhttp://localhost:6868
Описание каталога структуры проекта
|-- shotCat_doc
|-- LICENSE
|-- deploy.sh //用于自动部署
|-- package-lock.json
|-- package.json
|-- docs
| |-- README.md //文档首页配置
| |-- .vuepress //用于存放全局的配置、组件、静态资源等。
| | |-- config.js //文档配置文件
| | |-- enhanceApp.js //应用级别的配置 其实就是引入文档需要用到的第三方插件
| | |-- components //该目录中的 Vue 组件将会被自动注册为全局组件
| | | |-- baseComponent //文档会用到的全局公共组件
| | | | |-- apiTable.vue //组件的参数表格
| | | | |-- codeBox.vue //包裹示例的组件
| | | | |-- star.vue //底部彩蛋组件
| | | |-- demon //组件示例
| | | |-- catButton //存放button组件相关示例
| | | |-- type_catButton.vue
| | |-- dist //存放打包后的文件
| | |
| | |-- public //静态资源目录
| | | |-- favicon.jpeg
| | | |-- name.png
| | |-- styles //用于存放样式相关的文件
| | |-- index.styl //将会被自动应用的全局样式文件,会生成在最终的 CSS 文件结尾,具有比默认样式更高的优先级
| | |-- palette.styl //用于重写默认颜色常量,或者设置新的 stylus 颜色常量
| |-- components //存放组件文档要用到的markdown
| | |-- README.md
| | |-- 1.0 //1.0 版本的文档 如果不需要版本管理,直接删除1.0这层文件夹即可
| | | |-- README.md
| | | |-- catButton.md
| | |-- 2.0 //2.0 版本的文档
| | |-- README.md
| | |-- catButton.md
| |-- guide //使用说明的文件夹
| |-- introduction.md
| |-- quickStart.md
|-- src //存放你自己的ui组件库
|-- index.js
|-- components
|-- catButton
|-- catButton.vue
быстрый старт
step1
Поместите свою собственную библиотеку компонентов в корневой каталог и настройте ее в docs/.vuepress/enhanceApp.js.
//docs/.vuepress/enhanceApp.js
//引入你的组件库 确保你的组件库index文件有install方法
//如果不会,没关系,src目录里自带一个简单组件库示例,可供参考
import Cat from '../../src/index'
export default ({
Vue, // VuePress 正在使用的 Vue 构造函数
options, // 附加到根实例的一些选项
router, // 当前应用的路由实例
siteData // 站点元数据
}) => {
Vue.use(Cat)
}
Затем настройте путь к боковой панели.Для подробной настройки вы можете просмотреть комментарии непосредственно в docs/.vuepress/components/config.js.
// docs/.vuepress/components/config.js
//这里配置的是button组件页面的路径
sidebar:{
'/components/2.0/':[
{
title: '基础组件', // 必要的 配置侧边栏名称
path: '',
collapsable: false, // 可选的, 右侧侧边栏是否展开,默认值是 true
// 如果组件很多时,建议将children配置单独放到一个js文件中,然后进行引入
children: [
{
title:'Button 按钮',
path: 'catButton', //在项目中对应的路径是 docs/components/2.0/catButton.md
}]
}
]
},
step2
Теперь вы можете приступить к написанию собственной документации по компонентам, вот пример отображения компонента: возьмем в качестве примера мою кнопку-кошку
// docs/.vuepress/components/demon/catButton.vue
<template>
<!-- 注意这段代码会放入slot里,所以必须再包裹一层div,否则会解析报错 -->
<div>
<cat-button text="default"></cat-button>
<cat-button text="primary" type="primary"></cat-button>
<cat-button text="success" type="success"></cat-button>
<cat-button text="info" type="info"></cat-button>
<cat-button text="warning" type="warning"></cat-button>
<cat-button text="danger" type="danger"></cat-button>
<cat-button text="text" type="text"></cat-button>
</div>
</template>
<script>
export default {
}
</script>
step3
Создайте файл уценки в docs/components/2.0/catButton.md по указанному выше пути. Затем вы можете с радостью написать страницу компонента кнопки!
// docs/components/2.0/catButton.md
---
title: 2.0 Button 按钮
---
<!-- baseComponent-codeBox 组件即为.vuepress/components/baseComponent/codeBox文件,vuepress会默认把它解析为`baseComponent-codeBox`组件,这里我们如下对代码进行包裹,具体功能可以查看codeBox注释和页面效果 -->
<baseComponent-codeBox title="按钮类型" description="按钮类型通过设置type为primary、success、info、warning、danger、text创建不同样式的按钮,不设置为默认样式。" onlineLink="https://codepen.io/1011cat/pen/KjEOWO">
<!-- 同理demon-catButton-type_catButton即为我们step2编写的示例组件 -->
<demon-catButton-type_catButton></demon-catButton-type_catButton>
<!-- 这里highlight-code为引入的第三方代码高亮组件,里面包裹的就是上面示例组件的代码 -->
<highlight-code slot="codeText" lang="vue">
<template>
<div>
<cat-button text="default"></cat-button>
<cat-button text="primary" type="primary"></cat-button>
<cat-button text="success" type="success"></cat-button>
<cat-button text="info" type="info"></cat-button>
<cat-button text="warning" type="warning"></cat-button>
<cat-button text="danger" type="danger"></cat-button>
<cat-button text="text" type="text"></cat-button>
</div>
</template>
<script>
export default {
}
</script>
</highlight-code>
</baseComponent-codeBox>
<!-- 组件的参数表格,这里我没有使用自带的markdown表格,因为太丑,样式不好修改,有时参数描述较少时,不能自动撑满一行,所以自己写了一个组件;titile为表格标题,tableHead为表头,tableBody为具体参数设置,并且支持el-table的table参数 -->
<baseComponent-apiTable
title="Table Attributes"
:tableHead = "tableHead"
:tableBody = "tableBody">
</baseComponent-apiTable>
<!-- Vssue为引入的评论插件 -->
<Vssue title="Vssue Demo" />
<!-- 其实在vuepress里的每个.md其实和.vue很像的,你基本可以按照vue组件模式来写 -->
<script>
// 基本上和写vue一样
export default {
data() {
return {
//表头为字符串,写法和md一样,中间以`|`间隔就行
tableHead:`参数 | 说明 | 类型 | 可选值 | 默认值`,
//表头为数组,其中每一项为字符串,代表每一行要展示的数据,写法也和md一样,中间以`|`间隔就行
tableBody: [
`size | 尺寸 | String | medium / small / mini | —`,
`type | 类型 | string | primary / success / warning / danger / info / text | —`
],
}
},
}
</script>
<!-- 和vue一样,也可以设置样式,并且这里style样式只对当前md有效,不需要加上scoped -->
<style>
</style>
Итак, вы завершили отображение простого компонента кнопки, в двух словах:
- Настроить боковую панель навигации
- написать пример кода
- соответствующая страница md
Более подробная настройка и инструкции находятся в соответствующем коде. В каждом файле кода есть построчные комментарии и антипит-инструкции.
Если вам нравится этот проект добро пожаловатьstar!Или есть какие-либо проблемы с использованием и ошибки, добро пожаловать, чтобы представитьвыпуск и пр