使用 Turborepo 管理的 Monorepo 项目跨项目时如何共享代码

上篇文章中介绍了 Turborepo 管理 Monorepo 项目中可以通过内部库(Internal Packages) 的方式共享代码。

如果在同一个 Monorepo 项目中使用的,那么内部库就足够了,但是如果遇到多个项目同时需要使用公共的代码,那么就会需要考虑外部库(External Packages),相较于内部库而言,外部库会经过打包发布版本推送到一个集中的 npm 仓库提供给不同的项目使用,在跨项目使用的场景下使用,比如团队内基础组件库。

本文介绍使用 Turborepo 管理的 Monorepo 项目跨项目时如何共享代码,主要介绍外部库的打包和发布版本方式。

打包项目

发布到 npm 仓库的包都需要提前打包,使用者不需要直接引用源码,不需要知道实现细节可以直接使用,也避免了出现不同项目打包工具和配置不一样导致的打包问题。目前主流的打包工具都支持打包出 ECMAScript modules (esm)CommonJS modules (cjs),主流的项目脚手架和打包工具也都支持引入和打包这两种格式的第三方包。

目前主流的打包工具有 Webpack, Vite, Rollup 等,有各自的优劣势,本文将介绍使用 tsup 打包项目,是 Turborepo 文档 Bundling packages in a Monorepo -- Turborepo 中推荐的,支持 .js, .json, .mjs, .ts, .tsx 格式的文件的无配置打包,在小项目中上手使用十分方便快速。

以下目录结构为例,我们创建了一个库 math-helpers,并希望将他打包后发布

bash 复制代码
├── apps
│   └── web
│       └── package.json
├── packages
│   └── math-helpers
│       ├── src
│       │   └── index.ts
│       ├── tsconfig.json
│       └── package.json
├── package.json
└── turbo.json

安装 tsup

bash 复制代码
npm i tsup -D

定义打包命令

/packages/math-helpers/package.json 中定义打包命令,直接使用 tsup 打包 src/index.ts 的入口文件,并且导出 cjs,esm 格式和自动生成的类型定义

json 复制代码
{
  "scripts": {
    "build": "tsup src/index.ts --format cjs,esm --dts"
  }
}

将打包后的产物 dist 文件配置一下

  1. .gitignore 中忽略 dist,这部分不需要提交到 Git 项目
  2. 将打包后的产物地址 dist,添加到 turbo.json 中的 pipelineTurborepo 可以帮我们缓存打包结果,加快下次打包
json 复制代码
{
  "pipeline": {
    "build": {
      "outputs": ["dist/**"]
    }
  }
}
  1. package.json 中定义文件入口
json 复制代码
{
  "main": "./dist/index.js",
  "module": "./dist/index.mjs",
  "types": "./dist/index.d.ts"
}

更多 tsup 的使用方式可以参考 文档,或者参考使用其他打包工具,如 Vite

发布项目

项目打包完成后,需要考虑如何发布版本到 npm 仓库。其中包含这几件事:

  1. 版本管理,Semantic Versioning 还是 Calendar Versioning
  2. 发布
  3. npm 仓库,私有还是公开

在前端社区也已经有不少最佳实践和好用的工具来帮助我们完成发布项目这一流程。本文将介绍的是 Turborepo 文档 Versioning and Publishing Packages in a Monorepo -- Turborepo 中推荐的 changesets 这一工具和其推荐的发布流程。

安装并初始化

bash 复制代码
npm install @changesets/cli && npx changeset init

使用

初始化完成后,使用方式和流程基本就是以下三个命令。下面介绍下每个命令的作用

bash 复制代码
# Add a new changeset
changeset
 
# Create new versions of packages
changeset version
 
# Publish all changed packages to npm
changeset publish

添加更新说明

bash 复制代码
changeset

会生成一次更新说明,并且保存文件在项目中,可以执行多次,会生成多次更新说明,后续会根据这些更新说明来生成 CHANGELOG

当修改完成后,需要准备发布版本时

bash 复制代码
changeset version

会提供可交互的界面,选择需要发布的版本,按照 semver 规范,选择 patch, 'minor', 'major' 版本

这部分命令执行完后,会生成 CHANGELOG,和会自动更新 package.json 中的版本为正确的版本(需要提交到 Git),下一步即可发布到 npm 仓库

发布到 npm 仓库

bash 复制代码
changeset publish

这个命令代替了 npm publish 这个命令,会发布到 npm 仓库。(注意记得发布之前需要打包!!!)

发布完成后,其他项目既可以通过 npm install 的方式安装使用。在公司内部项目,一般都会使用内部 npm 仓库,如何发布到内部 npm 仓库是另一个话题,会在之后介绍。

参考链接

相关推荐
睡前要喝豆奶粉5 小时前
在.NET Core Web Api中使用JWT并配置UserContext获取用户信息
前端·.netcore
前端加油站5 小时前
一份实用的Vue3技术栈代码评审指南
前端·vue.js
Jonathan Star11 小时前
沉浸式雨天海岸:用A-Frame打造WebXR互动场景
前端·javascript
工业甲酰苯胺12 小时前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫12 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
LilySesy12 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
Wang's Blog13 小时前
前端FAQ: Vue 3 与 Vue 2 相⽐有哪些重要的改进?
前端·javascript·vue.js
再希13 小时前
React+Tailwind CSS+Shadcn UI
前端·react.js·ui
用户479492835691514 小时前
JavaScript 的 NaN !== NaN 之谜:从 CPU 指令到 IEEE 754 标准的完整解密
前端·javascript
群联云防护小杜14 小时前
国产化环境下 Web 应用如何满足等保 2.0?从 Nginx 配置到 AI 防护实战
运维·前端·nginx