当前位置:   article > 正文

git submodule简单使用_git submodule 初始化

git submodule 初始化

git submodule简单使用

好处: 允许一个git仓库,作为另一个git仓库的子目录,并且保持父项目和子项目相互独立。
1、提取公共的方法或样式,作为私有库给公司各项目使用
2、当项目过大时可以拆分为多个子模块,子模块之间相互独立。
本次主要是从新建项目到上传git,再到submodule的使用
首先是创建项目并上传git

//vue 2.X版本创建项目
vue init webpack  项目名称
//vue 3.创建版本
vue create 项目名称
  • 1
  • 2
  • 3
  • 4

git上新建项目并上传我们刚才创建的项目。git上创建项目仓库就不写了,网上百度都是的。接下来是将刚创建的项目上传到git上的仓库中
git的简单操作参考

cd 项目文件夹
git init
git add .
git commit -m 修改内容
git branch -M main
git push -uf origin main 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

哦吼 基本上这个时间问题就来了 提交不成功报错,为啥子呢 因为main分支权限的问题。可以重新创建分支也可以修改权限。我们选择第一个创建分支

git branch 分支名称
git checkout 分支名称
git add .
git commit -m 修改内容
git remote add origin https://..........
git push -u origin 分支名称
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

接下来是重点啦,在项目中使用submodule
1、直接添加子模块

git submodule add https://gitlab.com/zcy_hehe/git-tool.git git-tool
  • 1

2、添加子模块并指定分支

git submodule add -b <branch> <url> <path>
//比如:
git submodule add -b dev https://gitlab.com/zcy_hehe/shop-module.git shop-module
  • 1
  • 2
  • 3

项目中会多出一个git-tool、shop-module以及.gitmodules文件

请添加图片描述
请添加图片描述

公共js的使用方式跟日常的文件一致 通过import引入
在这里插入图片描述
子页面的使用方法也跟平时一样使用路由
请添加图片描述

页面效果达到预期~~ 完美
请添加图片描述

看一下git上有什么变化:
请添加图片描述

项目的仓库中多了个git-tool和shop-module的仓库地址。可点击
作为同组的小伙伴怎么使用带有submodule子模块的项目呢。
先clone父项目,再初始化submodule,最后更新submodule,初始化只需要做一次,之后每次只需要直接update就可以了,需要注意submodule默认是不在任何分支上的,它指向父项目存储的submodule commit id。

git clone https://github.com/***/mainProject.git mainProject
cd mainProject
git submodule init
git submodule update
  • 1
  • 2
  • 3
  • 4

更新子模块不成功的时候试一下

git submodule update --init --recursive
  • 1

修改submodule并更新
1、在主项目中修改submodule:可以看到下图,submodule自身会有个修改内容提交。主项目中有个关于submodule变化的提交。把这些都push到仓库中,其他小伙伴通过以下方式进行更新

git submodule update --init --recursive
  • 1

请添加图片描述
请添加图片描述
2、不在主项目中修改submodule,会发现使用git submodule update --init --recursive进行更新的时候没有用。
方法:从父仓库进入到modules目录(这个目录是submodule生成的比如我的项目是git-tool),调用

git pull //更新当前的子组件
  • 1

这个时候,打开我们的主项目会发现
请添加图片描述

然后把这个变化提交并push到仓库里,就能实现子模块的更新。
3、遇到使用分支的子模块更新不成功时,在主项目中查看子模块的当前分支

cd 子模块的文件夹
  • 1

查看当前子模块的分支发现是在main分支上,跟当前我们引入的分支不同,所以切换分支后再进行更新~~
请添加图片描述
删除submodule
当工程中不再需要子模块 git-tool时,可以执行以下命令:

git submodule deinit -f git-tool
  • 1

然后清除缓存

git rm --cached git-tool
  • 1

最后push到仓库

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/459335
推荐阅读
相关标签
  

闽ICP备14008679号