前言 作为一名专业的前端攻城狮,拥有可以解决需求的技术以外,对于代码的管理也是不可忽视的一点。多多少少写代码过程中,都无法避免不出现bug,遇到这种情况我们都想回到之前的哪一步,重新来过。如果每修改一点代码,都往本地保存一个备份的话,特别的消耗时间,也让程序猿没有办法专注于写代码。这时候就急需一个帮助来帮助我们管理代码的工具,那就跟着本文一起来学习一下git吧~
一、git
官网:git
1. 简介
Git 是一个免费的开源 分布式版本控制系统,旨在快速高效地处理从小到大的所有项目。
2. 作用
备份文件的变化,以便将来查阅或者 回到历史版本,使用历史版本的代码。 完成多人合作,轻松合并代码
3. 使用git 的重要性
工作场景一:项目的需求不断的变化,改来改去,也可能需要改回原来的代码。
- 使用版本管理软件
- 可以对代码每次的改动做记录,记录一次,叫做形成一个版本。
- 可以轻松的将代码回退到任意一个版本。(可以使用之前版本中的代码、文件)
- 电脑关机了,版本也不会丢失。
工作场景二:多个合作开发,代码不好合并。
- 使用版本管理软件 + 远程仓库,可以解决多人合作的问题。
使用git进行管理的作用
- 记录代码的版本,可以随时回退。
- 配合远程仓库,实现多人协作,可以很轻松的合并代码
版本管理软件的作用
- 记录代码的版本,可以随时回退。
- 配合远程仓库,实现多人协作,可以很轻松的合并代码
告诉Git,你是谁?
- 任何文件夹,空白处,右键 --> Git Bash Here
- 依次执行下面两行命令
git config --global user.name "xxx"
git config --global user.email "xxx"
配置之后,可以通过下面的命令来检查是否配置成功了
git config --list --global
git config user.name
初体验
使用Git记录代码的每一次变更
- 创建一个项目文件夹,随便创建一个即可。
- 在项目文件夹里面的空白处,右键 --> Git Bash Here,打开黑窗口。
- 在黑窗口中,输入
git init 然后按回车,表示执行这条命令。 - 这一步是Git初始化。初始化之后,表示Git软件可以管理这个项目了
- 对于一个项目来说,初始化工作只需要做一次。
- 写代码测试
- 随便写点代码
- 执行命令
git add . - 执行命令
git commit -m '提交说明' - 执行完这两个命令,表示使用Git把当前代码及文件的改动记录起来了
- 重复这个过程,多使用Git记录几次
查看所有的历史记录
查看提交日志
git log git log --oneline git log --reflog 或者 git log --oneline --reflog 查看所有的版本
体验在历史版本中穿梭
git reset --hard 版本号 — 通过它,让代码整体,可以在历史版本中穿梭
目前还有很多知识没有学习,所以,穿梭到历史之后,不要改代码,先体验一下穿梭的感觉。
穿梭到历史之后,如何查看所有的版本号
穿梭到历史版本之后,通过 git log 查看不到之后的版本号。
需要加 --reflog 选项,才能查看所有的版本号
git log --reflog git log --reflog --oneline
Git初始化详解
目的是学习,所以,随便创建一个项目文件夹,打开项目文件夹
注意:一定要在项目文件夹 ,右键–>Git Bash Here。
至于项目中有没有文件无所谓。
执行下面的命令:
# 初始化,表示使用Git管理我们的项目。这个命令只需要执行一次(注意空格)
git init
- 执行
git init 命令之后,会在项目文件夹中生成一个隐藏的 .git 文件夹 .git 文件夹里面保存着当前项目文件的更改记录。所以这个文件夹不能删除- 对于一个项目来说,
git init 只需要执行一次 - 切记,不要项目套项目。
查看日志详解
查看日志的命令:
git log
查看简略版的信息(前7位版本号 及 提交说明):
git log --oneline
git log --pretty=oneline
如果回到历史版本,还想查看完整的历史记录,需要使用 --reflog 选项。
git log --reflog --oneline
只查看最近的两次提交
git log -2
git log -2 --pretty=oneline
Git工作时涉及的几个区域
- 工作区
- 工作区,指的是使用Git管理后的文件,这些文件显示在磁盘上,供我们使用或修改的区域。所以,粗略的说,项目文件夹就是工作区。
- 暂存区
- 执行
git add . 之后,文件由工作区,添加到了暂存区。 暂存区保存了下次将提交的文件列表信息。 - Git 仓库区、本地仓库
- 执行
git commit -m '提交说明' 之后,代码会被提交到仓库区。仓库区是 Git 中最重要的部分,代码只有提交到仓库,才会形成一次历史记录,即才会形成一个版本。 - 远程仓库
- Git服务器上的仓库,比如,码云或者github网站上创建的的仓库,叫做远程仓库。远程仓库用于存储代码和发布项目,多人协作也需要远程仓库。
添加提交命令
添加文件到暂存区
新文件,只有添加到暂存区,才叫做被Git管理。否则和Git没什么关系,即使文件在项目文件夹。
git add 文件名
git add [file1] [file2] ...
git add [dir] [file] [dir] [file] [file] ...
git add .
默认空文件夹,是不能添加,不能提交的
提交文件到仓库
提交到仓库的文件,是暂存区中的文件。
git commit -m [message]
git commit [file1] [file2] ... -m [message]
git commit -a -m "提交日志"
撤销
撤销,是把暂存区的代码撤销到工作区;或者把最后一次提交的代码撤销到暂存区和工作区
- 暂存区 —> 工作区:
git checkout 文件 - 本地仓库 —> 暂存区:
git reset 文件 - 本地仓库 —> 暂存区/工作区:
git reset --hard
分支
分支就是当前项目的一个副本(可以理解为把当前项目复制了一份,可以这样理解,但是要知道内部实现并非如此)。
初始化之后,默认是在master分支上进行操作的,master分支也叫做主分支。
实际开发中,正规的公司,都不允许直接在master分支上开发。需要创建分支,在分支上开发,最后将代码合并回master。
分支常用命令
git branch
git branch 分支名
git branch login
git checkout 分支名
git checkout login
git checkout master
git branch -d 分支名
git branch -D 分支名 强制删除分支
git checkout -b 分支名
体验:
- 创建并切换到dev分支上;在dev分支上,写点代码,提交一下。
- 切换分支,查看两个分支的不同。
切换分支之前,必须把当前分支的代码全部提交到仓库。
|