位置: IT常识 - 正文

使用VitePress搭建及部署vue组件库文档(virtono搭建教程)

编辑:rootadmin
每个组件库都有它们自己的文档。所以当我们开发完成我们自己的组件库必须也需要一个组件库文档。如果你还不了解如何搭建自己的组件库可以看这里->从零搭建Vue3组件库。看完这篇文章你就会发现原来搭建和部署一个组件库文档是那么的简单。当然部署也不需要你有自己的服务器,你只要有github即可。由于我们的组件 ...

推荐整理分享使用VitePress搭建及部署vue组件库文档(virtono搭建教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vite搭建vue3,vijos搭建,vijos搭建,vtrul vps搭建教程,virtono搭建教程,virtono搭建教程,搭建vcenter,vite搭建项目,内容如对您有帮助,希望把文章链接给更多的朋友!

每个组件库都有它们自己的文档。所以当我们开发完成我们自己的组件库必须也需要一个组件库文档。如果你还不了解如何搭建自己的组件库可以看这里->从零搭建Vue3组件库。看完这篇文章你就会发现原来搭建和部署一个组件库文档是那么的简单。当然部署也不需要你有自己的服务器,你只要有github即可。由于我们的组件库还没有完成,所以下面就以element-plus作为示例来搭建一个文档吧。

安装vitepress

首先新建文件夹就叫kittydocs,执行pnpm init初始化,然后安装vitepress

pnpm add vitepress -D

在package.json添加一些script

"scripts": { "docs:dev": "vitepress dev docs", "docs:build": "vitepress build docs", "docs:serve": "vitepress serve docs" }

安装组件库element-plus

pnpm i element-plus -S目录结构

新建kittydocs目录,其中文件结构如下图

.vitepress/config.js为配置文件.vitepress/theme/index.js为自定义主题examples作为为组件示例目录public是公共文件目录index.md则是组件库文档的首页gulild放我们组件指南文档文档首页

首先我们按照官网的样式给我们组件库整个首页,在index.md文件中写入

---layout: hometitle: KittytitleTemplate: 一个Vue3组件库hero: name: Kitty text: 一个Vue3组件库 tagline: 没啥特点仅供学习 image: src: /logo.png alt: Kitty actions: - theme: brand text: 开始 link: /guide/ - theme: alt text: 在 Gitee 上查看 link: https://gitee.com/geeksdidi/kittyuifeatures: - icon: ? title: Vue3组件库 details: 基于vite打包和TypeScript开发 - icon: ? title: 仅供学习使用 details: 倾向于Vue3组件库的学习,请勿用于实际生产项目 - icon: ?️ title: 按需引入 details: 直接支持按需引入无需配置任何插件。---

然后pnpm run docs:dev启动我们的项目,我们就可以看到这样的画面

是不是感觉已经有点组件库文档的意思了。接下来对导航栏以及我们们文档的侧边栏进行一个配置。

配置导航栏配置export default { themeConfig: { siteTitle: false, logo: "/logo.png", nav: [ { text: "指南", link: "/guild/installation" }, { text: "组件", link: "/examples/button/" }, ], socialLinks: [{ icon: "github", link: "https://gitee.com/geeksdidi" }], },}

我们在config.js中配置我们的logo、导航栏以及社交链接。此时我们的导航栏便配置完成

侧边栏

首先我们对指南的侧边栏做一个配置

sidebar: { "/guild/": [ { text: "基础", items: [ { text: "安装", link: "/guild/installation", }, { text: "快速开始", link: "/guild/quickstart", }, ], }, { text: "进阶", items: [ { text: "xx", link: "/xx", }, ], }, ], },

同时我们在guild目录下新建installation.md和quickstart.md文件。接下来分别在这两个文件中介绍我们组件库的安装以及使用(这里将Element Plus当作我们自己的组件KittyUI)

installation.md# 安装## 环境支持由于 Vue 3 不再支持 IE11,KittyUI 也不再支持 IE11 浏览器。## 版本Element Plus 目前还在开发迭代中## 使用包管理器建议您使用包管理器 (NPM, Yarn, pnpm) 安装 KittyUI, 然后您就可以使用打包工具,例如 Vite 和 webpack# 选择一个你喜欢的包管理器# NPM$ npm install kitty-ui --save# Yarn$ yarn add kitty-ui# pnpm$ pnpm install kitty-ui## 浏览器直接引入暂不支持quickstart.md# 快速开始本节将介绍如何在项目中使用 KittyUI## 用法...<template> <Button>按钮</Button></template><script setup> import { Button } from 'kitty-ui'</script>...

这时候我们文档的效果如下

使用VitePress搭建及部署vue组件库文档(virtono搭建教程)

接下来我们对组件的侧边栏做一个配置,和指南一样,我们只需要在sidebar下再加个/examples/路径即可

"/examples/": [ { text: "基础组件", items: [ { text: "Button按钮", link: "/examples/button/", }, { text: "Icon图标", link: "/examples/Icon/", }, ], }, ],

vitepress中markdown文件中是可以直接使用vue组件的,我们先在theme/index全局引入element-plus

// .vitepress/theme/index.jsimport DefaultTheme from "vitepress/theme";import "element-plus/dist/index.css";export default { ...DefaultTheme, enhanceApp: async ({ app, router, siteData, isServer }) => { // app is the Vue 3 app instance from `createApp()`. router is VitePress' // custom router. `siteData`` is a `ref`` of current site-level metadata. import("element-plus").then((module) => { app.use(module); }); },};

这里我们拿Button做一个演示,在button/index.md中我们可以直接这样使用Button组件

<el-button>默认按钮</el-button><br/><br/><el-button>默认按钮</el-button><br/><br/><el-button type="primary">主要按钮</el-button><br/><br/><el-button type="success">成功按钮</el-button><br/><br/><el-button type="info">信息按钮</el-button>

此时我们页面即可展示我们的Button按钮

基于此,我们便可以轻松使用markdown文件的形式来编写我们的组件使用文档了。代码有点长,这里就贴一部分代码展示与隐藏的实现部分

完整的md文档你可以点击 index.md 直接查看。最后展示效果如下

其它组件实现方法基本一致,这里就不再一一实现了,接下来就是将我们的组件库文档部署到github的静态服务上了

部署到GitHub Pages

既然要部署到GitHub Pages,你得先在github新建一个仓库,因为要用他的GitHub Pages,所以仓库命名为username.github.io的形式,username是你github的用户名。然后点击设置

选择pages

这里设置根目录/(root),当然也可以选择其它目录,点击保存,如果选择其它目录比如docs,config.js就需要配置一个base

export default { base:'/docs/' }

最后选择一个主题(这里不选择我发现站点不生效,后面把打包后的代码推上来即可,会默认加载index.html)

然后将打包后的dist下的文件推送到你的远程仓库。vitepress官网给我们提供了一个脚本文件deploy.sh,我们只需要改下远程仓库即可

#!/usr/bin/env sh# 忽略错误set -e# 构建npm run docs:build# 进入待发布的目录cd docs/.vitepress/dist# 如果是发布到自定义域名# echo 'www.example.com' > CNAMEgit initgit add -Agit commit -m 'deploy'# 如果部署到 https://<USERNAME>.github.io# git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master# 如果是部署到 https://<USERNAME>.github.io/<REPO># git push -f git@github.com:<USERNAME>/<REPO>.git master:gh-pagescd -

直接执行这个脚本文件,我们的打包后的文件就会被推送到我们的仓库。然后我们就可以直接访问我们的文档站点了.如果你想要自定义其它域名的话,可以创建一个组织然后在组织下新建仓库名为organization.github.io的形式(organization是你组织名)然后执行同样的操作即可。具体可以点这里创建 GitHub Pages 站点最后代码已经推送到KittyUIDocs,需要的可以自行获取

创作不易,你的点赞就是我的动力!如果感觉这篇文章对你有帮助的话就请点个赞吧,谢谢谢!!

本文链接地址:https://www.jiuchutong.com/zhishi/313185.html 转载请保留说明!

上一篇:织梦调用列表页、文章页评论数和收藏数代码(织梦相关文章调用)

下一篇:Spring(十四):SpringAOP及AOP的三种实现方法(spring10)

  • facetime可以多人视频吗(facetime能多人吗)

    facetime可以多人视频吗(facetime能多人吗)

  • glk一al00什么型号(glk-al00是华为什么型号多少钱)

    glk一al00什么型号(glk-al00是华为什么型号多少钱)

  • 钢化膜能撕下来重贴吗(钢化膜能撕下来再贴吗)

    钢化膜能撕下来重贴吗(钢化膜能撕下来再贴吗)

  • 华为怎么划掉应用程序(华为怎么在应用划了后让它保持运行)

    华为怎么划掉应用程序(华为怎么在应用划了后让它保持运行)

  • 微信返回就收不到信息(手机微信返回主页就收不到发来的信息了)

    微信返回就收不到信息(手机微信返回主页就收不到发来的信息了)

  • 无线网需要认证怎么回事(无线网需要认证登录怎么解决)

    无线网需要认证怎么回事(无线网需要认证登录怎么解决)

  • 11年前的通话记录能找到吗(多年前的通话记录)

    11年前的通话记录能找到吗(多年前的通话记录)

  • 手机上一个眼睛一样的图像是什么(手机上面一个眼睛)

    手机上一个眼睛一样的图像是什么(手机上面一个眼睛)

  • 如何查看qq登录的地点位置(如何查看qq登录历史记录)

    如何查看qq登录的地点位置(如何查看qq登录历史记录)

  • 我的电脑图标在哪里找(我的电脑图标在哪)

    我的电脑图标在哪里找(我的电脑图标在哪)

  • 淘宝代付款怎么删除订单(淘宝代付款怎么删除)

    淘宝代付款怎么删除订单(淘宝代付款怎么删除)

  • 图像和声音的编码过程为(图像和声音的数字化包含()、()和()3)

    图像和声音的编码过程为(图像和声音的数字化包含()、()和()3)

  • 华为mate20x5G有几种颜色

    华为mate20x5G有几种颜色

  • i音乐怎么收藏自创歌单(apple music怎么收藏歌曲)

    i音乐怎么收藏自创歌单(apple music怎么收藏歌曲)

  • 闲鱼能申请退款几次(闲鱼能申请退款么)

    闲鱼能申请退款几次(闲鱼能申请退款么)

  • qq群坦白说什么意思(qq群坦白说会被发现吗)

    qq群坦白说什么意思(qq群坦白说会被发现吗)

  • 京东买家怎么删除评价(京东买家怎么删除赠品)

    京东买家怎么删除评价(京东买家怎么删除赠品)

  • 快手注销账户需要几天(快手注销账号最后一步)

    快手注销账户需要几天(快手注销账号最后一步)

  • 快应用服务框架哪里打开(快应用服务框架是什么东西)

    快应用服务框架哪里打开(快应用服务框架是什么东西)

  • vivoiqoo是几G手机(vivo手机是几g的)

    vivoiqoo是几G手机(vivo手机是几g的)

  • iphone微博缓存的视频在哪里(iphone微博缓存的视频在哪里可以找到)

    iphone微博缓存的视频在哪里(iphone微博缓存的视频在哪里可以找到)

  • 抖音隐私设置有什么用(抖音隐私设置有点赞和评论)

    抖音隐私设置有什么用(抖音隐私设置有点赞和评论)

  • 微信小程序 - 完美解决 web-view 公众号文章或第三方网站分享转发后,打开提示 “无法打开该页面,不支持打开” 或 “页面不存在”(IOS 苹果系统打开是空白页,安卓系统会有提示)超详细排查(微信小程序完美修真攻略)

    微信小程序 - 完美解决 web-view 公众号文章或第三方网站分享转发后,打开提示 “无法打开该页面,不支持打开” 或 “页面不存在”(IOS 苹果系统打开是空白页,安卓系统会有提示)超详细排查(微信小程序完美修真攻略)

  • AI遮天传 ML-无监督学习(遮天传贴吧)

    AI遮天传 ML-无监督学习(遮天传贴吧)

  • 税务师报名入口官网2022
  • 预提所得税的计税基础
  • 公司食堂菜金会计分录
  • 以前年度多缴的税款退回现金流量
  • 公司网站建设费做账是流量应计入
  • 预缴税款如何抵扣苗木款
  • 外来审计人员交通费
  • 实收资本记账凭证摘要怎么写
  • 通行费发票怎么合并一张发票
  • 建筑公司收到材料发票
  • 尚未收到货款,填什么凭证
  • 转让折旧怎么算
  • 销售商品收入确认的五个条件
  • 代理结算费用应该如何处理
  • 冲销去年费用
  • 纳税人是非开业户是什么意思
  • 增值税专票的收款人必须是个人嘛
  • 购买理财产品会损失本金吗
  • 企业转租房屋如何开票
  • 结息的会计分录怎么写
  • 维修材料费主要包括
  • 小规模纳税人取得专票如何处理
  • 生产型出口企业的概念
  • 委托贷款是流动资金贷款吗
  • 进项税转出补交的增值税和附加税可以税前扣除吗
  • 稿酬所得怎么纳税
  • 评估增值资产如何记账
  • 本地磁盘c满了怎么清理
  • 增加间接费用科目的方法
  • scheduler.exe - scheduler是什么进程 有何作用
  • imac 5k屏幕参数
  • 账务处理程序有什么
  • 工伤单位支付
  • 压缩模制
  • 工业企业销售收入和产值,税金比例
  • 发票开具的常见错误
  • 阿里云jar包
  • php rest api
  • 暂估纳税调增了账务怎么处理
  • 堡垒山是哪个国家
  • php实现数据库创建题库
  • php实现原理
  • 浅谈php中的错误处理方法
  • 已勾选确认的发票怎样撤销勾选
  • 内存分配理解是什么
  • 加工取得的存货成本会计分录
  • 销项税比进项税多怎么办
  • 租金摊销会计分录
  • 发票报销抵扣税点是给谁
  • 查账征收的优点
  • 机票 进项抵扣
  • 贷款购车怎么做会计分录
  • 增值税专用发票的税率是多少啊
  • 企业以非货币资产交换方式取得的长期股权投资
  • sql分组having
  • 如何删除windows media center
  • 笔记本用的上网卡
  • vmware虚拟化解决方案
  • mac锁定快捷键
  • 文件fwpkc1nt.sys
  • win10 sam文件下载
  • win10电脑磁盘损坏
  • win8系统保护已关闭 如何系统还原
  • linux常用命令查询
  • node.js有什么作用
  • python线程池最大数量
  • jquery滚动到底部
  • 用jQuery实现优酷首页轮播图
  • vue路由router
  • python中列表的遍历
  • unity2d序列帧
  • Jquery uploadify上传插件使用详解
  • jquery过滤选择器案例
  • dom使用
  • python查询系统
  • js封装是什么意思
  • 贸易公司的税率多少
  • 金税盘未反写
  • 干部任免审批表怎么填写
  • t+怎么取消记账凭证
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设