<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>Pnpm on Saiga</title>
    <link>http://localhost:1313/tags/pnpm/</link>
    <description>Recent content in Pnpm on Saiga</description>
    <generator>Hugo</generator>
    <language>zh-cn</language>
    <managingEditor>wuwenzen@outlook.com (wuwj)</managingEditor>
    <webMaster>wuwenzen@outlook.com (wuwj)</webMaster>
    <lastBuildDate>Sun, 15 Jan 2023 00:00:00 +0000</lastBuildDate>
    <atom:link href="http://localhost:1313/tags/pnpm/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>把多个前端项目合进一个 Monorepo 是怎样的体验</title>
      <link>http://localhost:1313/posts/2023-01-15-monorepo-migration/</link>
      <pubDate>Sun, 15 Jan 2023 00:00:00 +0000</pubDate><author>wuwenzen@outlook.com (wuwj)</author>
      <guid>http://localhost:1313/posts/2023-01-15-monorepo-migration/</guid>
      <description>&lt;p&gt;之前团队的前端项目是这样管理的：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;每个系统一个 Git 仓库；&lt;/li&gt;&#xA;&lt;li&gt;各自有一套构建脚本、一份依赖清单；&lt;/li&gt;&#xA;&lt;li&gt;公共组件、工具要么复制粘贴，要么用「半私有」的 NPM 包。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;结果就是：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;组件 bug 修一份，要手动同步 N 个仓库；&lt;/li&gt;&#xA;&lt;li&gt;依赖升级经常有「版本错乱」；&lt;/li&gt;&#xA;&lt;li&gt;CI 流水线一堆重复配置。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;于是我们决定把几个核心前端项目合到一个 Monorepo 里。&lt;br&gt;&#xA;这篇文章就是那次迁移的实战记录：&lt;strong&gt;工具选择、包划分、依赖管理、CI 改造，全流程。&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;1-为什么要搞-monorepo&#34;&gt;1. 为什么要搞 Monorepo？&lt;/h2&gt;&#xA;&lt;p&gt;总结下来就是三点：&lt;/p&gt;&#xA;&lt;ol&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;公共代码复用&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;组件库、Hooks、工具函数不用再复制粘贴；&lt;/li&gt;&#xA;&lt;li&gt;bug 修一次，多项目同步升级。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;一致的工程规范&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;统一 ESLint/Prettier/Commit 规范；&lt;/li&gt;&#xA;&lt;li&gt;统一构建脚手架和发布流程。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;协同开发体验好&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;打开一个仓库就能看到相关项目；&lt;/li&gt;&#xA;&lt;li&gt;修改组件立刻能在多个应用里验证。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;p&gt;当然，Monorepo 不是银弹，仓库会变大、CI 要更精细。&lt;br&gt;&#xA;所以「是否值得」的标准是：&lt;/p&gt;&#xA;&lt;blockquote&gt;&#xA;&lt;p&gt;&lt;strong&gt;项目之间有明显共享，且会长期共同演进。&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;/blockquote&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;2-工具选型pnpm--turborepo&#34;&gt;2. 工具选型：pnpm + Turborepo&lt;/h2&gt;&#xA;&lt;p&gt;我们调研了一圈：Lerna、Nx、Yarn Workspaces、pnpm Workspace、Turborepo……&lt;br&gt;&#xA;最后选的是：&lt;strong&gt;pnpm Workspace + Turborepo&lt;/strong&gt;，原因：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;pnpm：硬链接节省磁盘空间、依赖管理清晰、速度快；&lt;/li&gt;&#xA;&lt;li&gt;Turborepo：任务编排 + 缓存好用，学习成本相对较低。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;21-仓库结构&#34;&gt;2.1 仓库结构&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;repo-root&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── apps&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   ├── manager-web        &lt;span style=&#34;color:#75715e&#34;&gt;# 管理端&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   ├── investor-web       &lt;span style=&#34;color:#75715e&#34;&gt;# 投资人 Web&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   └── mini-program       &lt;span style=&#34;color:#75715e&#34;&gt;# 小程序（uni-app 等）&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── packages&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   ├── ui-components      &lt;span style=&#34;color:#75715e&#34;&gt;# 通用 UI 组件库&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   ├── shared-utils       &lt;span style=&#34;color:#75715e&#34;&gt;# 工具函数&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;│   └── eslint-config      &lt;span style=&#34;color:#75715e&#34;&gt;# 统一 ESLint 配置&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── package.json&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── pnpm-workspace.yaml&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;└── turbo.json&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;&lt;code&gt;pnpm-workspace.yaml&lt;/code&gt;：&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
