内容简介:我们开发项目的时候,会经常碰到可服用模块,比如各种现在我们项目中用了俩种模式子模块允许你将一个 Git 仓库作为另一个 Git 仓库的子目录。 它能让你将另一个仓库克隆到自己的项目中,同时还保持提交的独立。
背景
我们开发项目的时候,会经常碰到可服用模块,比如各种 utils包
, 登录
, 分享
之类的共有模块,并不想写在项目本身,而是抽出来可以为多个项目所复用。
现在我们项目中用了俩种模式
- 把公共模块打包成npm包,使用时候利用npm install安装
- 公共组件单独写成一个项目,使用时用git submodule引入到主项目中
利用git submodule实现
子模块允许你将一个 Git 仓库作为另一个 Git 仓库的子目录。 它能让你将另一个仓库克隆到自己的项目中,同时还保持提交的独立。
添加git子模块
git 通过在 git submodule add 命令后面加上想要跟踪的项目 URL 来添加新的子模块。
$ git submodule add https://github.com/chaconinc/DbConnector Cloning into 'DbConnector'... remote: Counting objects: 11, done. remote: Compressing objects: 100% (10/10), done. remote: Total 11 (delta 0), reused 11 (delta 0) Unpacking objects: 100% (11/11), done. Checking connectivity... done.
克隆含有子模块的项目
接下来我们将会克隆一个含有子模块的项目。 当你在克隆这样的项目时,默认会包含该子模块目录,但其中还没有任何文件:
$ git clone https://github.com/chaconinc/MainProject $ cd DbConnector/ $ ls $
其中有 DbConnector 目录,不过是空的。 你必须运行两个命令:git submodule init 用来初始化本地配置文件,而 git submodule update 则从该项目中抓取所有数据并检出父项目中列出的合适的提交。
$ git submodule init Submodule 'DbConnector' (https://github.com/chaconinc/DbConnector) registered for path 'DbConnector' $ git submodule update
不过还有更简单一点的方式。 如果给 git clone 命令传递 --recursive 选项,它就会自动初始化并更新仓库中的每一个子模块。
$ git clone --recursive https://github.com/chaconinc/MainProject Cloning into 'MainProject'...
在包含子模块的项目上工作
以上所述就是小编给大家介绍的《处理公共模块 对比npm包和git submodule》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 使用模块化工具打包自己开发的JS库(webpack/rollup)对比总结
- 前端每周清单第 16 期:JavaScript 模块化现状;Node V8 与V6 真实性能对比
- 常用消息队列对比
- 各类排序算法对比
- 商城框架对比初稿
- 各种编程语言对比
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。