git 创建版本库 2 种方式:
- git init : 直接将一个文件夹变成一个仓库
mkdir learn-git
cd learn-git
git init
- git clone : 从已有仓库克隆下来同名仓库
git clone https://github.com/xxxx/remote-repo.git
data:image/s3,"s3://crabby-images/2dc13/2dc13095415387a718495c5120b8477f37b1fb04" alt=""
git 三个工作区域:
- 工作区 Working Directory
- 暂存区 Staging Area/Index
- 本地仓库 Local Repository
data:image/s3,"s3://crabby-images/b7d6e/b7d6ec0af9f1f1a8034407e3b0f2ad244763c303" alt=""
git 三个仓库的推进关系
data:image/s3,"s3://crabby-images/401d9/401d9a9202d878779afb8e0c63344439cd022da5" alt=""
文件所处状态与操作
data:image/s3,"s3://crabby-images/39fc7/39fc75debaf9d0a6b449b9c9d08039e7d84fb1d5" alt=""
git 提交文件步骤
git init // 创建仓库
git status // 查看仓库的状态
git add // 文件添加到暂存区
git commit // 提交文件到本地仓库
git log [--oneline] // 查看提交日志
data:image/s3,"s3://crabby-images/a34d4/a34d483f527d26166279561919c4a41b9bd5ed94" alt=""
git reset 回退到之前的某一个“版本”
git reset 回退有3种模式:
- soft 模式:保留工作区和暂存区内容
- hard 模式:删除工作区和暂存区内容
- mixed 模式:只保留工作区内容
data:image/s3,"s3://crabby-images/31423/314231aa79442ba7db515538a9f834a7ad2595f4" alt=""
例如:soft 模式回退
git reset --soft 5af90b8
data:image/s3,"s3://crabby-images/be737/be737d26206052f1aec9abf1342bda045cccdcfe" alt=""
例子: hard 模式回退
git reset --hard HEAD^ // 使用 hard 回退模式回退到上一版本(HEAD^ 指上一版本)
data:image/s3,"s3://crabby-images/7d306/7d30643018f0b1a81f9530ccee49167af536326c" alt=""
- git reset soft 和 mixed 使用场景是当你觉得仓库中几个版本的提交没有太大意义时,可以通过这2中模式进行版本的回退,然后重新 add 和 commit, 提交一个新的有意义的版本。
- git reset hard 模式是你真的要放弃本地所有要修改内容的时候,要谨慎使用 hard 模式。但是如果不小心误操作的话,可以使用 git reflog 命令来查看我们操作的历史记录 。通过 git reflog 可以查询到误操作命令的前一个版本号。
git diff 查看差异
data:image/s3,"s3://crabby-images/a832e/a832e453d2b58123c0ddd4065d16324407f30b26" alt=""
git diff // 比较工作区和暂存区的差异
git diff HEAD // 比较工作区和版本库的差异
git diff --cached // 比较暂存区和版本库的差异
git diff 5abdefd 6dfdgsd // 比较2个版本直接的差异
git diff HEAD^ HEAD // 比较前一版本和当前版本差异
git diff HEAD~ HEAD // 比较前一版本和当前版本差异
git diff HEAD~2 HEAD // 比较 HEAD 之前的 2 个版本
git diff HEAD~2 HEAD file3.txt // 只比较指定文件这间的版本差异
git rm 删除文件
rm file // window 或 linux 下删除“工作区”文本
git add file // 只有加上只一步才能完整从暂存区删除文件
git rm file // 把文件从工作区和暂存区同时删除
git rm --cached file // 把文件从暂存区删除,但是保留在当前工作区中
data:image/s3,"s3://crabby-images/02cad/02cad389d70b75f2725863fb49bcf8f704591318" alt=""
ignore git 应该忽略文件
.ignore 文件生效的前提是忽略的文件不能是已经被添加到版本库里面的。
data:image/s3,"s3://crabby-images/5c2fc/5c2fc2fbc8b7fafa2cbb504fec8d245921ed16f5" alt=""
data:image/s3,"s3://crabby-images/07569/07569977663c8cc83ed3f34e9dcc522643a952bc" alt=""
git 远程仓库
- 可以通过 git remote -v 命令查看当前仓库所对应远程仓库的别名和地址
git remote -v
data:image/s3,"s3://crabby-images/cf5d4/cf5d4a3579ecda4bae5f1e4fce61fd6081ec3b4b" alt=""
- 将本地仓库与远程仓库关联起来
git remote add origin git@github.com/xxx/first-repo.git // origin 就是我们远程仓库的别名
git branch -M main // 指定分支的名称为 main
git push -u origin main // 将本地的 main 分支与远程 origin main 分支关联起来 -u --up-stream-to
git pull origin main:main // 拉取远程仓库内容
网友评论