monorepo 实战练习

1. 项目初始化

json 复制代码
# 创建项目目录
mkdir my-monorepo
cd my-monorepo

# 初始化项目
pnpm init

# 安装开发依赖
pnpm add -D typescript eslint prettier @changesets/cli

编辑根目录 package.json

json 复制代码
{
  "name": "my-monorepo",
  "version": "0.0.0",
  "private": true,
  "scripts": {},
  "devDependencies": {
    "@changesets/cli": "^2.26.0",
    "eslint": "^8.40.0",
    "prettier": "^2.8.8",
    "typescript": "^5.0.4"
  }
}

2. 配置工作空间(workspace)

新建 pnpm-workspace.yaml

json 复制代码
packages:
  - 'packages/*'
  - 'apps/*'
  - 'tools/**'

💡 这样定义后,packages/apps/tools/ 目录下的所有子目录都会作为子包(package)纳入管理。

3 创建子项目

3.1 创建工具包:统一 TypeScript 配置 (tools/typescript-config)

json 复制代码
# 创建目录
mkdir -p tools/typescript-config
cd tools/typescript-config

# 初始化 package.json
pnpm init

编辑 tools/typescript-config/package.json

json 复制代码
{
  "name": "@workspace/typescript-config",
  "version": "1.0.0",
  "private": true,
  "files": [
    "base.json",
    "nextjs.json",
    "react-library.json",
    "vue-library.json"
  ]
}

新增基础 TypeScript 配置文件:

  • tools/typescript-config/base.json
  • tools/typescript-config/nextjs.json
  • tools/typescript-config/react-library.json
  • tools/typescript-config/vue-library.json

💡 @workspace/typescript-config 这个包的作用是:统一管理项目中所有子包的 TypeScript 配置,保证一致性,避免每个子包重复配置。

3.2 创建通用工具库 (packages/utils)

json 复制代码
# 创建目录
mkdir -p packages/utils/src
cd packages/utils

# 初始化 package.json
pnpm init

编辑 packages/utils/package.json

json 复制代码
{
  "name": "@workspace/utils",
  "version": "1.0.0",
  "private": true,
  "type": "module",
  "main": "dist/index.js",
  "module": "dist/index.mjs",
  "types": "dist/index.d.ts",
  "files": ["dist/**"],
  "scripts": {
    "build": "tsup src/index.ts --format esm,cjs --dts",
    "dev": "tsup src/index.ts --format esm,cjs --watch --dts"
  },
  "devDependencies": {
    "@workspace/typescript-config": "workspace:^",
    "lodash": "^4.17.21",
    "tsup": "^8.4.0"
  }
}

创建源码文件:

  • src/index.ts
  • src/format.ts
  • src/validation.ts
  • src/string.ts

💡 @workspace/utils 这个包的作用是:封装通用工具函数(如字符串处理、日期格式化、表单校验等)供各应用共享使用

3.3 创建 Web 应用项目 (apps/web)

json 复制代码
# 创建目录
mkdir -p apps/web/src
cd apps/web

# 初始化 package.json
pnpm init

编辑 apps/web/package.json

json 复制代码
{
  "name": "web",
  "version": "1.0.0",
  "private": true,
  "type": "module",
  "main": "./dist/index.js",
  "module": "./dist/index.mjs",
  "types": "./dist/index.d.ts",
  "scripts": {
    "dev": "tsc -w",
    "build": "tsup src/index.ts --format esm,cjs --dts"
  },
  "dependencies": {
    "@workspace/typescript-config": "workspace:^",
    "@workspace/utils": "workspace:^",
    "tsup": "^8.4.0"
  }
}

创建入口文件 src/index.ts

json 复制代码
import { capitalize } from '@workspace/utils';

const str = 'hello world';
console.log(capitalize(str));

新增 tsconfig.json

json 复制代码
{
  "extends": "@workspace/typescript-config/base.json",
  "compilerOptions": {
    "baseUrl": ".",
    "outDir": "./dist",
    "rootDir": "./src"
  },
  "include": ["src/**/*.ts"],
  "exclude": ["node_modules", "dist"]
}

4 安装所有依赖

在项目根目录执行:

json 复制代码
pnpm install

5 构建与开发

构建所有包:

json 复制代码
pnpm build

开发模式下启动 Web 应用:

json 复制代码
pnpm --filter web dev

运行打包产物:

json 复制代码
cd apps/web/dist
node index.js

输出:

json 复制代码
Hello world

6 小结

通过这个实战,我们搭建了一个完整的 Monorepo 基础架构,包括:

  • 工具包:统一的 TypeScript 配置
  • 通用库:工具函数、组件库
  • 应用项目:Web 网站、管理后台等

使用了:

  • pnpm workspace 统一管理依赖
  • Tsup 快速打包构建
  • TypeScript 保证类型安全

这种结构可以随着项目扩大,灵活地扩展新的库或应用,同时保持良好的组织性和开发效率。

相关推荐
QQ1__8115175154 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态4 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子4 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室4 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI4 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing4 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者4 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册4 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李5 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢5 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web