![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLicmbw5SYmNTNxgTO0kzM3kzM0U2MzcDM3EmZ1QTY3QGMiRjYl9CX0JXZ252bj91Ztl2Lc52YucWbp5GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.png)
看的课程是Lynda上面因此也就不PO出来了,因为大家也没法点进去.
Git本质上是一种版本控制系统,它能够让我们跟踪工程的进度.
在本地安装好Git之后, Git Bash能够帮助我们使用UNIX的命令.
- cd 命令能够帮助我们切换路径,比如切换到desktop的project文件中,我们使用
cd ~/Desktop/project
2. git init 可以帮助我们初始化某个文档作为一个Git repository
3. ls -la 你会发现一个.git 文件,这个文件能够帮助跟踪所有的改动在你的project中。
4. Git有两个不同的的地方能够存储文件。第一个是staging environment, 你能够添加任何的文件到这个环境中通过git add命令.
比如使用 git add index.html
第二个就是你本身就处于的环境
5.你可以通过git status观察到变化
我的电脑在这儿其实出了点问题,因此我使用
6. rm -rf .git 去重置了文件源
最后的结果是你会看到两行第一行是 change to be commited,第二行是 untracked files.
第一行意味着能够被committed
第二行意味着还没有被跟踪,说明Git都不知道关于about.html这个文件,
7.很多时候你会面临一大堆的文件想要添加,这种一个一个添加的命令显然不是特别够用,因此我们使用'git add .'这个命令即是全部添加,OK,我们搞定了,然后使用git status命令去查看一下几个文件的状态.
你可以一直保持那些加入的文件直到你想去提交他们 作为一个永久的文件.
8.git commit -m ''revision one''接下来我们就使用这个命令来提交文件作为第一个版本
提交后再使用git status 命令 我们就什么都不能发现了
9. git log 命令能够调取你提交的log信息
10.如果你改动文档 这时候使用git status 命令能够再次得到变动的文件
第一行表示这不是在staging的环境中,那么后面两行就是两个操作,第一个我们讲过了,也就是添加到staging 的环境中,第二个就是回滚到我们之前的revision one中.
11. git checkout -- index.html
这时候我们会发现内容已经回滚完毕了
12. 当使用git add . 命令后,我们再使用 git status 确认状态, 我们发现在staging environment中, 文件名变绿了,因此可以接着submit
13.当我们没有submit再修改的时候,我们会发现一个很有意思的东西
然后我们发现原来staging的文件依旧在,我们可以通过git reset HEAD index.html进行删除第二次修改,然后我们得到
这其中就是第三次修改
如果我们不断的修改 不断的保存 然后commit 之后我们使用git log,我们能够得到一个log日志
14. what is gonna happen when I delete a file?
那么首先我先删除一个文件 然后使用git status进行查看,那么我会看到
在这儿之后,我有两个选择-也就是两个在框框中列出来的内容
第一个是git checkout -- about.html 这有点像是撤回键,那么我们能够看到about.html 回来了
第二个是git add -- about.html, 把这个文件加入到staging 环境中
不过这个操作也能撤回(unstagged),就像在上图中括号里指出的那样 git reset HEAD about.html
之后再使用git status 就看到了 跟之前相同的一个状态
然后我们再使用 git checkout -- about.html
15. 当我们使用git rm about.html 的时候,我们会发现
about.html文件删除了
因此,git rm about.html这个命令相当于你手动删除,然后使用git add about.html 的结果
要撤回的话就是 git reset HEAD about.html 到 git checkout about.html
16. 当我们删了不知道什么东西或者很多很多东西需要进行批量操作的时候
我们使用 git add --all 把所有东西都push到staging 环境中
17. 接下来我们看一下怎么管理log文件
由于隐私,我就不po我win10上的图了,po个视频上mac的
我们可以使用 git checkout +某个对应版本的commit 来回滚到某个版本
然后改变index的内容,之后使用git status 的得到
先暂时忽略两个括号里的命令,先使用git add . 命令把文件添加到staging environment
然后得到
然后我们commit这个文件 by git commit -m "alternate one"
我们能够得到一段log 当我们使用git log命令的时候
如果你想回到上一个分支,分支这个词在git中表示一系列我们的修改方向(可以把他当成衍生的树枝),使用git branch 得到
master实际上就是我们的主枝,然后我们只要输入 git checkout master,就又回滚到原来的主枝干上了
如果你想再回滚到之前的branch,你得记住 87eef2d这串号码,在不同的电脑上不同,记住就好了。
18. 然后使用git branch +另一个branch想要的名字+ 这串号码,我们就能新创一个branch啦
19. 之后使用git branch 这个命令读取branch的名字
我们得到两个branch的名字,然后可以使用git checkout alternate进行回滚
20. 创建新的branch,可以直接使用 git branch + name
21. 当我们想要融合两个branch的时候,比如把app01融入到master的时候,首先我们要确认我们在master这个branch中,然后使用git merge app01
22.改branch的name,我们需要git branch -m +原名 +新名
23.删除某个branch, git branch -D +名字