nodejs项目Monorepo模式的基础操作

简单说明

Monorepo(一仓多包),主要是指nodejs环境下的项目,简单说就是在一个git代码仓库下,把项目拆分为多个package,可以分别开发但又互相协作。

举例

一个nodejs环境下的全站项目,需要前后端分离,这很自然的就会产生一个情况,前后端后使用一些共同的定义,比如复杂的接口参数。这时,把这些接口参数的定义,放到一个公共的地方,就是一个很自然很合理的做法。这就是Monorepo的一个基础使用场景。 技术上,Monorepo需要使用pnpm的workspace。

项目搭建过程

shell 复制代码
// 首先全局安装pnpm
npm install -g pnpm

// 创建项目基本目录
mkdir prj_root
// 在项目根目录下init
pnpm init

// 如果确定的话,可以先安装一些公用的包在根目录 比如vite
pnpm add vite -w
pnpm add -D typescript -w
pnpm add -D @types/node -w

// 创建tsconfig
pnpm tsc --init

// 创建pnpm的workspace管理文件
touch pnpm-workspace.yaml

pnpm-workspace.yaml中写入

yaml 复制代码
packages:
    - 'packages/*'

下面进行子包的操作

共享库 shared

shell 复制代码
// 创建packages目录,在其中进行多包的操作
cd prj_root && mkdir packages

// 先创建共享库
cd packages && mkdir shared && pnpm init && pnpm tsc --init

// 创建 src/index.ts
// 先写一个简单的interface 代码不贴了
    
// 

后端 backend

shell 复制代码
cd packages && mkdir backend && pnpm init && pnpm tsc --init
 

子包的tsconfig要继承根目录的tsconfig

json 复制代码
{
  "extends": "../../tsconfig.json",
  "compilerOptions": {
    "outDir": "./dist",
    "rootDir": "./src"
  }
}

添加共享包

shell 复制代码
// 通过workspace方式添加
pnpm add @agent4/shared@workspace:*

前端frontend

shell 复制代码
// 前端子包操作
相关推荐
CainChen2 小时前
Chrome 远程调试 Android 卡在 Pending authentication 的解决办法
前端
杨运交2 小时前
[030][Web模块]Spring Boot 验证与 OpenAPI 集成实战:从校验规则到文档生成
前端·spring boot·python
天le2 小时前
基于cocos3.x复刻《猪了个猪》挪了个船:位置生成实现
前端
青木_JS2 小时前
qiankun 子应用重开后仍显示旧数据?问题出在模块顶层的 useStore()
前端
货拉拉技术2 小时前
面向 Agent Skill 的 CLI/SSO 鉴权体系:安全、无感、可追溯
前端·agent
ssshooter3 小时前
为什么父元素的高度不会包含子元素的 margin?
前端·javascript·面试
静Yu3 小时前
从一个九宫格素材小程序,看轻量工具产品该如何优化体验
前端·微信小程序
程序员黑豆3 小时前
AI全栈开发之Java:第一个Java程序
前端·后端·ai编程
小Q的编程笔记3 小时前
Pump.fun 的核心是什么?用 300 行 Solidity 实现 Bonding Curve 与自动 LP 销毁
前端·后端·智能合约
卷帘依旧3 小时前
React Fiber机制
前端