远程仓库
Git 远程仓库相当的操作实际可以归纳为两点:向远程仓库传输数据以及从远程仓库获取数据。
Clone
克隆远程仓库代码 克隆过来的项目代码是一般是没有node_modules文件夹的,需要用npm i(全写:install) 下载所用的依赖
git clone <远程仓库地址>
练习: 执行前 data:image/s3,"s3://crabby-images/e9325/e93256a4d33f219a88857fddd79e82fdf5c76565" alt="在这里插入图片描述"
git clone
执行后 data:image/s3,"s3://crabby-images/78007/78007a779e20beb5915b59b2b1a8f0a261141629" alt="在这里插入图片描述"
远程分支
远程分支(类似origin/master等)反映了远程仓库(在你上一次拉远程代码时)的状态,在你检出时自动进入分离 HEAD 状态。 远程分支命名规范:
<remote name>/<branch name>
origin/master
练习: 执行前 data:image/s3,"s3://crabby-images/b6203/b620303516c4de8227072b52566afc0d098d3ba4" alt="在这里插入图片描述"
git checkout o/master
git commit
执行后 data:image/s3,"s3://crabby-images/29d7d/29d7d0f1ed0ec4b132826f90bf7d3b65c3b5d9b3" alt="在这里插入图片描述" commit提交后,就分离 出HEAD 状态,当添加新的提交时 o/master 也不会更新。这是因为 远程分支只有在远程仓库中相应的分支更新了以后才会更新。 例子: data:image/s3,"s3://crabby-images/56735/567356a7b4b27b52756f54c23842e37c2605b673" alt="在这里插入图片描述"
git commit
git checkout o/master
git commit
fetch
从远程仓库获取数据 fetch 通常通过互联网(使用 http:// 或 git:// 协议) 与远程仓库通信。 将本地仓库中的远程分支更新成了远程仓库相应分支最新的状态。 fetch 并不会改变你本地仓库的状态。也不会修改你磁盘上的文件 练习: 执行前 data:image/s3,"s3://crabby-images/975f0/975f0cc8c35b5637cca5e868450fa836ede3f1f7" alt="在这里插入图片描述"
git fetch
从远程仓库下载本地仓库中缺失的提交记录;更新远程分支指针( o/master)。
执行后 data:image/s3,"s3://crabby-images/a1487/a1487890c2b7287de07ee7c3c89a3a20e48fe797" alt="在这里插入图片描述" 例子练习:
git fetch
data:image/s3,"s3://crabby-images/e5c18/e5c186afcb14cc59de5a424fedec3bcee9d33e71" alt="在这里插入图片描述"
Pull
更新远程分支代码,与本地分支分支合并 若远程仓库只有一条分支可直接使用git pull,若有多条分支则使用 git pull <远程仓库名称>/<分支名称>
执行前: data:image/s3,"s3://crabby-images/19e8c/19e8c52efc5038ce0d32591bae27c597c20d6597" alt="在这里插入图片描述"
git fetch
git merge o/master
执行后: data:image/s3,"s3://crabby-images/a818c/a818c4a9530707566e10931a1661bb78a44a2102" alt="在这里插入图片描述"
git pull == git fetch;git merge <分支名>;
例子练习:
git pull
git fetch
git merge o/master
data:image/s3,"s3://crabby-images/6742d/6742d407ce2ebe05dbf8f1694101f8a957226571" alt="在这里插入图片描述"
模拟团队提交
git fakeTeamwork :在远程仓库的 分支(默认是master)上做提交。
git fakeTeamwork <分支名> Num(提交次数)
git fakeTeamwork develop 3
git fakeTeamwork
执行前: data:image/s3,"s3://crabby-images/589d0/589d06c314d19cc231f94ee30e5c652ec53b32bd" alt="在这里插入图片描述" 执行后
git fakeTeamwork
data:image/s3,"s3://crabby-images/67c1f/67c1f3de1b3f5e255f7db91fb364a46eca6cf562" alt="在这里插入图片描述"
执行前 data:image/s3,"s3://crabby-images/7f9d8/7f9d8f0921f44fe9bd816339cce5e76ce1f5498f" alt="在这里插入图片描述" 执行后
git fakeTeamwork foo 3
data:image/s3,"s3://crabby-images/6601a/6601a60dfe066ed9024304dbbe408260b39edac2" alt="在这里插入图片描述" 例子练习: data:image/s3,"s3://crabby-images/1bd68/1bd68436008d978661bfecf1c00ef282265e3e0e" alt="在这里插入图片描述"
git clone
git fakeTeamwork 2
git fetch
git commit
git merge o/master
git commit
git pull
push
负责将本地分支的变更上传到指定的远程仓库,并在远程仓库上合并新的提交记录,然后更新本地的远程分支
执行前 data:image/s3,"s3://crabby-images/600f0/600f007500b37e5056c18ce71d2fc5b17a0e0550" alt="在这里插入图片描述" 执行后
git push
data:image/s3,"s3://crabby-images/facc7/facc778c1ab77c786c15b3e46eb0dba627ce759e" alt="在这里插入图片描述" 例子练习 data:image/s3,"s3://crabby-images/ddcd4/ddcd45a0f1c8844cdac839bf2bc104a0dd17e432" alt="在这里插入图片描述"
git commit
git commit
git push
推送冲突(偏离的工作)
远程仓库中的分支是最新,而本地仓库中的代码是旧,远程仓库中有更改,与本地的有冲突
执行前 data:image/s3,"s3://crabby-images/256a5/256a524a066fba69deb7b5cd507551f8cfec3791" alt="在这里插入图片描述"
执行后
git fetch
git rebase o/master
git push
data:image/s3,"s3://crabby-images/e3982/e398202446e9684da38beade4f1ddadb326b4923" alt="在这里插入图片描述" 执行前 data:image/s3,"s3://crabby-images/ee20a/ee20a251f7e8086dc2242e916c643f1add470491" alt="在这里插入图片描述"
执行后
git fetch
git merge o/master
git push
data:image/s3,"s3://crabby-images/15213/152136f1f0a515cc92715ab4404608e8e40519d5" alt="在这里插入图片描述"
git pull == git fetch;git merge <branch>
git pull --rebase == git fetch;git rebase <branch>
执行前 data:image/s3,"s3://crabby-images/12680/12680e45aed4b97ba2f3938bf9a5e2188def2c1f" alt="在这里插入图片描述" 执行后
git pull --rebase
git push
例子练习 data:image/s3,"s3://crabby-images/1f716/1f716a6fe607872d6262fafa39667f16f9684519" alt="在这里插入图片描述"
git clone
git fakeTeamwork
git commit
git pull --rebase
git push
|