前端工程化之多个项目如何同时高效管理 — monorepo

2023-10-30 21:48

本文主要是介绍前端工程化之多个项目如何同时高效管理 — monorepo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

monorepo 不仅限于前端,但此篇博文只谈前端。

是什么

wikipedia: In version control systems, a monorepo (“mono” meaning ‘single’ and “repo” being short for ‘repository’) is a software development strategy where code for many projects is stored in the same repository.

翻译过来就是:在版本控制系统中,monorepo 是一种软件开发策略,其中许多项目的代码存储在同一存储库中。

为什么

在公司内,如果项目较多,每一个项目都会有一个Git仓库,就会导致新来的员工每一次更改项目的时候都需要从 Git 仓库上面拉一份代码下来比较麻烦。

那如果将所有的项目放在一个仓库一起管理呢?这就是 monorepo。

优点

  1. 对依赖统一进行管理。
  2. 可以抽取逻辑维护公共库。
  3. 所有项目统一配置相同的工程配置。

缺点

  1. 需要有比较严格的 CR 规范。
  2. Git 权限管理难以控制。
  3. 版本控制比较麻烦

项目都需要规范的流程。

怎么做

目前来说,前端算是有两种比较常见的对 monorepo 的方案:

  1. lerna.js
  2. yarn workspace

当然,它们也可以同时使用。

yarn workspaces

它允许设置多个包,即只需运行一次 yarn 安装即可一次性安装所有包。

package.json文件中添加以下内容

{"private": true,"workspaces": ["workspace-a", "workspace-b"]
}
禁止使用

.yarnrc 文件中添加:

workspaces-experimental false

learn.js

Github 仓库在:https://github.com/lerna/lerna

Lerna is a tool that optimizes the workflow around managing multi-package repositories with git and npm.

Lerna 是一个使用 git 和 npm 优化管理多包存储库的工作流程的工具。

需要注意的是:lerna 只是一个优化工作流程的工具,并不是一个部署工具。

安装
# 新建一个项目
mkdir lerna-demo && cd lerna-demo# 初始化项目
npm init -y# 安装 lerna
yarn add lerna -D# 初始化 lerna 的项目
npx lerna init

此时一个最基本的 lerna 项目算是完成了。

(记得添加 .gitignore )

使用

上述的命令完成之后,现在项目的文件目录:

在这里插入图片描述

更改一下 package.json 在其中加一个字段:

{"private": true,// ...
}

由于我们管理的是子项目,一般不对父项目进行发布处理,所以将 private 设置为 true

然后在 packages 目录中新建项目即可。

lerna 会自动检测到 packages 里面的项目进行管理。

packages 目录中的项目需要注意一件事情:

  • package.json 的 name 字段需要和文件夹的名称相同。
命令
  • lerna init: 初始化
  • learn list: 列出现在管理的项目
  • lerna diff: 列出最近一次 release 的区别
  • lerna change: 更改了哪些 package
  • lerna bootstrap: 安装依赖并且链接任何交叉依赖项
  • lerna clean: 清理所有依赖项
  • lerna exec: 在每个 package 执行命令
  • lerna run: 在包含 npm script 中的每个 package 执行 npm script
  • lerna import: 将 package 导入到具有提交历史记录的 monorepo 中
  • lerna link: 将相互依赖的所有 package 符号链接在一起

同时使用

lernayarn workspace 可以同时使用

lerna.json 添加:

{"packages": ["packages/*"],"version": "0.0.0","npmClient": "yarn","useWorkspaces": true
}

然后在 package.json 添加:

{// ..."private": true,"workspaces": ["packages/*"]
}
区别

yarn workspace 中有这么一段:

Yarn’s workspaces are the low-level primitives that tools like Lerna can (and do!) use. They will never try to support the high-level feature that Lerna offers, but by implementing the core logic of the resolution and linking steps inside Yarn itself we hope to enable new usages and improve performance.

这个就是区别

参考

wikipedia Monorepo: https://en.wikipedia.org/wiki/Monorepo

yarn workspace: https://classic.yarnpkg.com/en/docs/workspaces

lerna github: https://github.com/lerna/lerna

这篇关于前端工程化之多个项目如何同时高效管理 — monorepo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/310779

相关文章

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

C#高效实现在Word文档中自动化创建图表的可视化方案

《C#高效实现在Word文档中自动化创建图表的可视化方案》本文将深入探讨如何利用C#,结合一款功能强大的第三方库,实现在Word文档中自动化创建图表,为你的数据呈现和报告生成提供一套实用且高效的解决方... 目录Word文档图表自动化:为什么选择C#?从零开始:C#实现Word文档图表的基本步骤深度优化:C

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

input的accept属性让文件上传安全高效

《input的accept属性让文件上传安全高效》文章介绍了HTML的input文件上传`accept`属性在文件上传校验中的重要性和优势,通过使用`accept`属性,可以减少前端JavaScrip... 目录前言那个悄悄毁掉你上传体验的“常见写法”改变一切的 html 小特性:accept真正的魔法:让

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

C#实现将Excel工作表拆分为多个窗格

《C#实现将Excel工作表拆分为多个窗格》在日常工作中,我们经常需要处理包含大量数据的Excel文件,本文将深入探讨如何在C#中利用强大的Spire.XLSfor.NET自动化实现Excel工作表的... 目录为什么需要拆分 Excel 窗格借助 Spire.XLS for .NET 实现冻结窗格(Fro