plugin-light
采用 pnpm monorepo
模式,灵感来自于 Vue3 和 Vite 项目。
开发前需对 pnpm
常用命令有基本了解。
以 project-config-vite
为例:
pnpm --filter=@plugin-light/project-config-vite build
升级依赖
# 在某个包中升级 一些依赖
pnpm --filter=@plugin-light/project-config-vite up "@plugin-light/*"
# 在所有包中只升级 某个依赖
pnpm --filter="./packages/*" up "@plugin-light/shared-vue2"
# 除了某个包外,其他包升级依赖
pnpm --filter="\!./packages/plugin-light-shared" up "@plugin-light/shared"
根据jsdoc
生成文档:
npm run docs:gen
文档开发:
npm run docs:dev
文档打包:
npm run docs:build
文档部署:
npm run docs:deploy
shared
为 Vue2 和 Vue3 公用的。
shared-vue2
为 Vue2 独有的,可能会用到 loader-utils
、vue-template-compiler
等库。
这样拆离是为了防止依赖版本冲突。
loader
、plugin
之间不能互相依赖,project-config
之间也是。如果有公用部分,请抽离到 shared
中。
shared
、loader/plugin
、project-config
依赖关系如下:
project-config
/ \
|
loader、plugin
/ \
|
shared
每个 loader
有 3 个产物,外部可以使用。
- index.js
- loader.js
- loader.prod.js
index.js
是具名导出,包含 LOADER
、LOADER_PROD
两个变量,分别对应 loader.js
、loader.prod.js
的文件路径,并导出 loader
的 types
。
loader.js
和 loader.prod.js
分别是 loader
的非压缩版本和压缩版本。
另外,webpack-loader-publish
虽然不是 loader
,但是为了方便管理和维护,采用了与 loader
一致的导出模式。