news 2026/4/22 17:46:27

前端Monorepo入门:从零开始搭建你的第一个项目

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端Monorepo入门:从零开始搭建你的第一个项目

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
    创建一个适合新手的Monorepo教学项目,使用pnpm workspace管理包含两个简单React应用的代码库。要求提供分步指导,包括初始化配置、共享组件开发、依赖安装和脚本命令设置,并附带详细注释说明。
  3. 点击'项目生成'按钮,等待项目生成完整后预览效果

最近在研究前端工程化,发现很多大厂项目都在用Monorepo管理代码。作为一个刚接触这个概念的新手,我花了一周时间摸清了基本玩法,今天就用最直白的语言分享从零搭建的过程,适合像我一样的小白快速上手。

1. 什么是Monorepo?

简单说就是把多个项目放在同一个代码仓库里管理。比如公司有官网、后台、小程序三个前端项目,传统方式是开三个Git仓库,而Monorepo则放在同一个仓库的不同目录下。好处特别明显:

  • 共享代码更方便(比如统一的工具函数库)
  • 依赖包版本统一管理
  • 跨项目修改能一次性提交

2. 准备工作

我用的是pnpm+workspace方案,相比yarn/npm更节省磁盘空间。需要先安装:

  1. 到官网下载安装pnpm(建议版本7.0+)
  2. 新建空文件夹作为仓库根目录
  3. 终端执行pnpm init生成package.json

3. 初始化Monorepo结构

关键步骤是配置workspace,在根目录创建pnpm-workspace.yaml文件,指定子项目位置。比如我的结构:

  • /packages/admin (后台管理系统)
  • /packages/web (官网项目)
  • /shared (公共组件库)

对应的workspace配置只要写:

packages: - 'packages/*' - 'shared'

4. 创建React子项目

以admin项目为例:

  1. 进入packages目录
  2. 用vite快速初始化React项目:pnpm create vite admin --template react-ts
  3. 同样步骤创建web项目

这时候打开任意子项目的package.json,会发现依赖都安装在各自node_modules里。接下来我们要优化这个情况。

5. 提升公共依赖

在根目录执行:

pnpm add react react-dom -w
-w参数表示安装到workspace根节点,这样所有子项目会共用同一份react代码。可以通过pnpm list查看依赖树验证。

6. 开发共享组件

在shared目录新建Button组件:

  1. 初始化package.json(注意设置"name": "@shared/ui")
  2. 编写React组件代码
  3. 在admin和web项目中通过pnpm add @shared/ui -F admin安装(-F指定安装到特定项目)

现在修改Button组件时,两个项目会实时同步更新,不用手动复制粘贴。

7. 配置统一脚本

根目录的package.json可以添加这些实用命令:

"scripts": { "dev": "pnpm --parallel -r dev", "build": "pnpm -r build", "lint": "pnpm -r lint" }

解释几个参数: - -r 在所有子项目运行 - --parallel 并行执行(适合dev热更新) 现在执行pnpm dev能同时启动所有前端项目!

8. 调试技巧

遇到最多的问题是依赖引用报错,分享两个排查方法:

  1. pnpm why 包名查看依赖被哪些项目引用
  2. 在vscode安装Workspace插件,能可视化查看项目关系

9. 进阶优化方向

等熟悉基础操作后,可以继续探索:

  • 接入Changesets管理版本发布
  • 配置Turborepo加速构建
  • 集成Storybook管理组件库

最近在InsCode(快马)平台看到有现成的Monorepo模板,比自己配环境省心多了。他们的在线编辑器可以直接调试,部署按钮一点就能生成演示链接,特别适合新手快速验证想法。像我这样的小白第一次搭Monorepo用了三天,现在用平台半小时就能跑通全套流程,建议大家都去试试看。

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
    创建一个适合新手的Monorepo教学项目,使用pnpm workspace管理包含两个简单React应用的代码库。要求提供分步指导,包括初始化配置、共享组件开发、依赖安装和脚本命令设置,并附带详细注释说明。
  3. 点击'项目生成'按钮,等待项目生成完整后预览效果

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 17:01:01

多功能热处理生产线普及为紧固件行业带来效率革命

历经十五届持续发展,上海紧固件专业展(FES)已经发展成为“全球紧固件三大专业展之一“。其展商、展品质量,活动内容,国内外买家到访数量,现场成交金额等多个方面都具有标杆性的影响力,2025年更在…

作者头像 李华
网站建设 2026/4/18 9:10:43

架构师自诉:如何做到百万数据半小时跑批结束

业务背景跑批通常指代的是我们应用程序针对某一批数据进行特定的处理在金融业务中一般跑批的场景有分户日结、账务计提、欠款批扣、不良资产处理等等具体举一个例子 🌰客户在我司进行借款,并约定每月 10 号码还款,在客户自主授权银行卡签约后…

作者头像 李华
网站建设 2026/4/22 11:49:38

计算相机的插值和适配分辨率尺寸

相机插值计算原理插值(缩放)是指将原生低分辨率 Sensor(如 5MP/8MP)通过算法放大到 13MP,核心是「像素补全」(双线性 / 双三次插值),计算核心公式:插值缩放因子 √(目标…

作者头像 李华
网站建设 2026/4/21 4:12:41

营销组合建模终极指南:Meridian框架完全解析

营销组合建模终极指南:Meridian框架完全解析 【免费下载链接】meridian Meridian is an MMM framework that enables advertisers to set up and run their own in-house models. 项目地址: https://gitcode.com/GitHub_Trending/meri/meridian 在当今竞争激…

作者头像 李华
网站建设 2026/4/19 11:20:41

技术应用 | UV-C LED赋能耳机充电仓:实现高效杀菌与健康防护

随着真无线耳机(TWS)的广泛应用,其日常清洁与消毒问题正受到越来越多的关注。耳机长期与皮肤及耳道接触,容易积聚细菌、耳垢与汗液,若未得到有效清洁,可能增加耳部不适或感染的风险。传统清洁方式&#xff…

作者头像 李华
网站建设 2026/4/16 11:55:35

可信数据空间如何重塑数字经济生态?

当前,数据已被确立为关键生产要素。然而,数据要素潜力的充分释放,长期受制于流通不畅、利用不足、安全难保等现实困境。数据持有方因担心权益受损而“不愿流通”,因技术门槛和合规风险而“不敢流通”,因缺乏高效可信的…

作者头像 李华