1、git init
- 在命令行输入
git init
,初始化文件,会出现一个隐藏的文件加.git
,此时代表当前这个文件夹及其以下内容都被git管理了。 - 在dome建立一个
js
文件,vscode
会显示U文件后缀标记 - 作用:创建生产暂存区和本地仓库
2、git status
- 查看文件的状态,红色表示工作区,绿色表示暂存区
3、git add
将工作区的文件提交的暂存区
- git add 文件 # 将单独一个文件添加到暂存区(可以为空)
- git add . #将当前文件夹的所有文件都添加都暂存区
- git add ./文件夹 # 将整个文件夹添加到暂存区(git不管理空文件夹)
- git add --all # 将当前文件夹中所有文件和文件夹都添加到暂存区 - 简写:git add .
4、git reset
将暂存区的文件拉回到工作区
- git reset HEAD – 文件 # 将某个文件从暂存区变为源文件
- git reset HEAD – 文件夹 # 将整个文件夹从暂存区变为源文件
- git reset HEAD – . # 将所有文件从暂存区变为源文件
- git reset – 文件或文件名 #将文件从历史(本地)区拉到暂存区
5、git commit
将暂存区文件提交到本地仓库
- git commit -m “版本号或注解信息”#将文件从暂存区提交的到本地创库
6、git log
查看版本信息
- git log#查看提交目录及版本信息
- git log --oneline #简洁的日志信息及版本号
7、git config
如果是**第一次提交,**需要配置提交者信息,推荐和github
的账号邮箱一致
git config user.name
你的目标用户名
git config user.email
你的目标邮箱名
使用–global参数,配置全局的用户名和邮箱,只需要配置一次即可。推荐配置github的用户名和密码
git config --global user.name 你的目标用户名
git config --global user.email 你的目标邮箱名
查看配置信息
git config --list
#初始化指定的配置项
git config --unset --global user.email
git config --unset --global user.name
8、版本回退
返回指定版本
- git reset --hard HEAD^ # 有几个上档键就回退几个版本
- git reset --hard 历史版本号 #将代码回退到指定的版本号,重置所有区
9、git diff
查看每次提交的内容的不同
- git diff #查看工作区与暂存区的不同
10、创建分支
git branch
分支名 #创建分支,分支中的代码,在创建时与当前分支的内容完全相同。
- git在第一次提交时,就有了一个叫
master
的主分支。 - 注意,不能在分支下面创建分支
11、查看分支
git branch
#查看所有的分支
12、切换分支
- git checkout 分支名 #切换到指定的分支
- git checkout -b 分支名 #创建并转到此分支
13、删除分支
git branch
-D 分支名 #删除此分支
- 注意:不能在当前分支删除当前分支,需要切换到其他分支才能删除。
- 注意:
master
主分支是可以删除的,但是不推荐那么做。
14、恢复删除的分支
git branch
分支名 分支id
#如果记不住分支名和id,可以通过reflog命令进行查找,如
git reflog
#显示所有版本信息和历史提交信息
15、分支合并
git merge
分支名 #将其他分支合并到当前的分支
16、合并冲突
- 对于同一个文件,如果有多个分支需要合并时,容易出现冲突。
- 合并分支时,如果出现冲突,只能手动处理,将提示冲突的内容删除,再次提交,一般的作法,把自己的代码放到冲突代码的后面即可。
17、远程仓库
github
- git是一个版本控制工具
github
是一个代码托管平台,开源社区,是git的一个远程代码仓库。
git clone
- 作用:克隆远程仓库的代码到本地
- git clone [远程仓库地址]
git push
- 作用:将本地仓库中代码提交到远程仓库
- git push 远程仓库地址 分支名
git push 远程仓库地址 本地分支名:远程分支名
git push -u 远程仓库地址 分支名 #使用-u后第二次上传只需要git push就可以 - 首次推送远程需要会到网页面输入用户名和密码
git pull
- 作用:将远程的代码下载到本地、或者是本地与远程同步。意义都一样
- 通常在push前,需要先pull一次。进行一次同步
- git pull #不用怀疑,就这,没别的参数
git remote
每次push操作都需要带上远程仓库的地址,非常的麻烦,我们可以给仓库地址设置一个别名
设置别名
- git remote add 仓库别名 仓库地址
- git remote add origin git@github.com:*********/test.git
ssh免密登陆
- 创建密钥:本机存放。
- 打开cmd,执行以下命令:
- 创建SSH Key:
ssh-keygen -t rsa -C "远程仓库地址"
- 在文件路径
C:\用户\当前用户名\
找到 .ssh/id_rsa.pub.文件夹 - 将文件的内容复制到github上:
- 头部最右侧头像-》 settings ->SSH and GPG keys->SSH keys:->new ssh key
- 粘贴