Git
版本库原理
Git 的版本库里存了很多东西,其中最重要的就是称为 stage(或者叫 index)的暂存区,还有 Git 为我们自动创建的第一个分支 master,以及指向 master 的一个指针叫 HEAD。
工作区有一个隐藏目录.git,这个不算工作区,而是 Git 的版本库
创建版本库:
# 创建文件
$ mkdir myapp
#进入文件
$ cd myapp
#初始化代码仓库
$ git init
#把需要提交的所有修改放到暂存区(Stage)$ git add file
#提交所有文件
#$ git add .
#提交所有.js 格式文件
#$ git add *.js
#强制添加
#$ git add -f file
#提交代码
$ git commit -m "commit info"
查看
# 查看历史记录,git log 命令显示从最近到最远的提交日志
$ git log
#查看分支合并图
$ git log --graph
#Git 提供了一个命令 git reflog 用来记录你的每一次命令:$ git reflog
#git status 命令用于显示工作目录和暂存区的状态。使用此命令能看到那些修改被暂存到了, 哪些没有, 哪些文件没有被 Git tracked 到。git status 不显示已经 commit 到项目历史中去的信息。$ git status
#当暂存区中没有文件时,git diff 比较的是,工作区中的文件与上次提交到版本库中的文件。#当暂存区中有文件时,git diff 则比较的是,当前工作区中的文件与暂存区中的文
$ git diff
#比较工作区中的文件与版本库中文件的差异。HEAD 指向的是版本库中的当前版本,而 file 指的是当前工作区中的文件。$ git diff HEAD -- file
版本回退:
#Git 必须知道当前版本是哪个版本,在 Git 中,用 HEAD 表示当前版本,上一个版本就是 HEAD^,上上一个版本就是 HEAD^^,当回退版本较早时可以写成 HEAD~100。#版本回退
$ git reset --hard HEAD^
#取消回退,commitId 为你想要回到的未来版本号
$ git re**set** --hard commitId
撤销修改
命令 git checkout ——file 把文件在工作区的修改全部撤销,这里有两种情况:
* 一种是 file 修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;* 一种是 file 已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
# 文件在工作区的修改全部撤销
$ git checkout --file
删除文件
命令 git rm 用于从版本库删除一个文件。
如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
# 从版本库删除一个文件
$ git rm file
提示:先手动删除文件,然后使用 git rm <file> 和 git add<file> 效果是一样的。
添加远程仓库
# 关联一个远程库
$ git remote add origin <address>
#第一次将本地库的所有内容推送到远程库上
$ git push -u origin master [-f]
#此后,每次本地提交后, 就可以使用命令推送最新修改
$ git push origin master
从远程库克隆
#
git clone [url]
比如,要克隆 Ruby 语言的 Git 代码仓库 Grit,可以用下面的命令:
# 这会在当前目录下创建一个名为 grit 的目录,其中包含一个.git 的目录,用于保存下载下来的所有版本记录,然后从中取出最新版本的文件拷贝。如果进入这个新建的 grit 目录,你会看到项目中的所有文件已经在里边了,准备好后续的开发和使用。$ git clone git://github.com/schacon/grit.git
如果希望在克隆的时候,自己定义要新建的项目目录名称,可以在上面的命令末尾指定新的名字:
# 唯一的差别就是,现在新建的目录成了 mygrit,其他的都和上边的一样。$ git clone git://github.com/schacon/grit.git mygrit
分支管理
创建 + 切换分支:
$ git checkout -b <name>
创建分支:
$ git branch <name>
切换分支
$ git checkout <name>
查看分支:
#git branch 命令会列出所有分支,当前分支前面会标一个 * 号。$ git branch
切换分支
# 切换回 master 分支
$ git checkout <name>
合并某分支到当前分支
$ git merge <name>
删除分支
$ git branch -d <name>
Git 分支十分强大,在团队开发中应该充分应用。
合并分支时,加上—no-ff 参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而 fast forward 合并就看不出来曾经做过合并。
储藏
储藏 可以获取你工作目录的中间状态——也就是你修改过的被追踪的文件和暂存的变更——并将它保存到一个未完结变更的堆栈中,随时可以重新应用。
现在你想切换分支,但是你还不想提交你正在进行中的工作;所以你储藏这些变更。为了往堆栈推送一个新的储藏,只要运行 git stash。把所有未提交的修改(包括暂存的和非暂存的)都保存起来,用于后续恢复当前工作目录。
git stash
需要说明一点,stash 是本地的,不会通过 git push 命令上传到 git server 上。
查看现有的所有储藏,此命令显然暗示了 git stash 可以多次保存工作进度,并用在恢复时候选择。
$ git stash list
重新应用已经实施的储藏(不删除储藏)
# 如果你想应用更早的储藏,你可以通过名字指定它,像这样:git stash apply stash@{2}。如果你不指明,Git 默认使用最近的储藏并尝试应用它
$ git stash apply [--index] [<stash>]
重新应用已经实施的储藏(删除储藏)
# 如果不使用任何参数,会恢复最新保存的工作进度,并将恢复的工作进度从存储的工作进度列表中清除。#如果提供 <stash> 参数(来自 git stash list 显示的列表),则从该 <stash> 中恢复。恢复完毕也将从进度列表中删除 <stash>。#选项 --index 除了恢复工作区的文件外,还尝试恢复暂存区。$ git stash pop [--index] [<stash>]
删除一个存储的进度。(默认删除最新的进度)
$ git stash drop [<stash>]
清空当前所有的 stash
$ git stash clear
基于储藏进度创建分支。
$ git stash branch <branchname> <stash>
多人协作
查看远程库的信息:
# 或者用 git remote -v 可显示更详细的信息
$ git remote
推送分支,该分支上的所有本地提交推送到远程库
$ git push origin <branch-name>
从本地推送分支,如果推送失败,先抓取远程的新提交:
$ git pull
我是 Cloudy,年轻的前端攻城狮一枚,爱专研,爱技术,爱分享。
个人笔记,整理不易,感谢阅读、点赞和收藏。
有任何问题欢迎大家指出,也欢迎大家一起交流前端各种问题!