sidebar: auto

贡献指南

概览

项目仓库借助于 pnpm 工作空间 来实现 Monorepo ,在 packages 目录下存放了多个互相关联的独立 Package 。

  • @vuepress/core: Core 模块。提供 Node API 来创建 VuePress App ,包括页面逻辑、插件系统、数据准备等功能。

  • @vuepress/client: Client 模块。包含客户端页面入口,并提供了客户端开发时可以用到的类型和工具函数。

  • @vuepress/bundler-vite: 基于 Vite 的 Bundler 模块。使用 Vite 对 VuePress App 执行 devbuild 操作。

  • @vuepress/bundler-webpack: 基于 Webpack 的 Bundler 模块。使用 Webpack 对 VuePress App 执行 devbuild 操作。

  • @vuepress/cli: 命令行接口 (CLI) 模块。包含解析用户配置文件、调用 @vuepress/core 创建 VuePress App 、调用 @vuepress/bundler-${name} 来执行对应命令等功能。

  • @vuepress/theme-default: 默认主题。

  • @vuepress/plugin-${name}: 官方插件。

  • @vuepress/shared: 既可以在 Node 端使用、也可以在客户端使用的工具函数模块。

  • @vuepress/utils: 仅可以在 Node 端使用的工具函数模块。

  • vuepress: 是 vuepress-vite 的封装。

  • vuepress-vite: 是 @vuepress/cli + @vuepress/bundler-vite + @vuepress/theme-default 的封装。如果用户想使用 默认主题 + Vite ,仅安装这个 Package 就可以了。

  • vuepress-webpack: 是 @vuepress/cli + @vuepress/bundler-webpack + @vuepress/theme-default 的封装。如果用户想使用 默认主题 + Webpack ,仅安装这个 Package 就可以了。

开发配置

开发要求:

克隆代码仓库,并安装依赖:

  1. pnpm install

构建源代码:

  1. pnpm build

开始开发项目文档网站:

  1. pnpm docs:dev

本项目开发使用的一些主要工具:

开发脚本

pnpm build

build 命令会使用 tsctsup 将 TypeScript 源文件编译为 JavaScript 文件。

此外,它还会将必要的资源文件从源文件目录复制到输出目录。这是因为一些资源文件不会被 tsctsup 处理,但它们仍需要被放置到输出目录,并保持它们的项目对路径不变。

你在克隆代码仓库后,可能需要先执行该命令来确保项目代码可以顺利运行,因为编译后的输出目录被 .gitignore 排除在仓库以外了。

pnpm clean

clean 命令会执行所有子 Package 中的 clean 命令,清除所有的输出文件目录和缓存文件。换言之,它将移除所有通过 buildcopy 命令生成的文件。

当你想要从最初状态重新构建源代码时,你可以执行该命令。

pnpm dev:*

dev: 前缀表明,这些命令是针对开发使用的,将会以监听模式运行对应的脚本。

pnpm docs:*

pnpm docs:build, pnpm docs:dev, pnpm docs:clean

docs: 前缀表明,这些命令是针对文档 (documentation) 进行操作的,即 docs 目录。

VuePress 使用它自己来构建自己的文档网站。

你需要先执行 pnpm build 来构建 VuePress 源代码,然后再运行这些 docs: 开头的命令来开发或构建文档。

pnpm docs:serve

在本地启动文档网站服务器。

你需要先运行 pnpm docs:build 来生成文档网站的输出文件,然后再通过该命令来启动文档网站。

pnpm lint

lint 命令使用 ESLint 来检查所有源文件。

pnpm test

test 命令使用 Jest 来运行单元测试。

文档

VuePress 的文档是由 VuePress 自己驱动的,是由该仓库中的源码构建而来。

所有的 Markdown 源文件都放置在 docs 目录下。我们维护了两种翻译:

  • 英语 (en-US) 在 / 路径下
  • 中文 (zh-CN) 在 /zh/ 路径下

我们部署了两套站点: