git命令行推送本地分支到远程仓库

之前说过Git与IDEA强强联合(HTTPS协议连接)那么如何使用命令行来推送代码呢?

如下图所示为一个基于layui的前端代码:

在这里插入图片描述
目录工作区文件:
git命令行推送本地分支到远程仓库_第1张图片
git命令行推送本地分支到远程仓库_第2张图片

本地内容就是将这些内容推送到远程仓库

首先使用git命令初始化git本地仓库:

  • git init创建本地仓库

在这里插入图片描述
以出现.git命令为参考:
git命令行推送本地分支到远程仓库_第3张图片
创建git仓库后vs code也有颜色的变化:
git命令行推送本地分支到远程仓库_第4张图片
除了颜色的变化外还有字母呢U,它们的含义是:

红色,未加入版本控制; 
绿色,已经加入版本控制暂未提交;
蓝色,加入版本控制,已提交,有改动;
白色,加入版本控制,已提交,无改动;
灰色:版本控制已忽略文件。

git文件标识:
A: 增加的文件.
C: 文件的一个新拷贝.
D: 删除的一个文件.
M: 文件的内容或者mode被修改了.
R: 文件名被修改了。
T: 文件的类型被修改了。
U: 文件没有被合并
X: 未知状态

然后绑定用户名和邮箱,便于记录提交者信息:

  • git config --global user.namegit config --global user.email

在这里插入图片描述
将需要提交的文件或代码提交到暂存区:

  • git add将文件添加到缓存区

如果之前选择在根目录的上级创建git仓库的话使用 git add [dir]dir为路径添加到缓存区,或者使用git add filename添加指定目录至缓存区。如果是在根目录内部,直接git add .将当前更改文件添加到缓存区,如下图所示:

git命令行推送本地分支到远程仓库_第5张图片
warning: LF will be replaced by CRLF出现该警告的原因是不同系统下的换行符不一样,只需了解即可,git会自动检测系统内核,将换行符自动转换,具体了解请移步IDEA和VS code设置默认换行符为LF感谢作者!

由于git在push时会自动转换,所以直接统一格式,简单很多。这个得看个人用的上面系统,Windows默认是crlf,Linux默认是lf。直接将vs code的换行符改为LF,并且关闭自动转换,这样就不需要所谓的转换,在任何系统都可以使用。

在这里插入图片描述
注意将git的自动转换功能关闭:git config --global core.autocrlf false

git config --global core.autocrlf true
Git可以在你push时自动地把行结束符CRLF转换成LF,而在pull代码时把LF转换成CRLF。用core.autocrlf来打开此项功能,如果是在Windows系统上,把它设置成true,这样当签出代码时,LF会被转换成CRLF,如果本来就是LF,就会两者自动转换。

git config --global core.autocrlf input
Linux或Mac系统使用LF作为行结束符;当一个以CRLF为行结束符的文件不小心被上传时需要进行修正,把core.autocrlf设置成input来告诉 Git 在push时把CRLF转换成LF,pull时不转换

git config --global core.autocrlf false  关闭自动转换功能

在这里插入图片描述

关闭后就不再警告了,但是本地的换行符必须是LF。

可以看到文件全部变成了A,已添加到了本地库:

git命令行推送本地分支到远程仓库_第6张图片

  • git remote add origin [远程仓库地址]添加远程仓库

git remote -v查看远程仓库路径

在这里插入图片描述

git remote add origin [addr]添加远程仓库

登录gitee选择仓库,复制仓库地址,在命令行添加

git命令行推送本地分支到远程仓库_第7张图片
https地址的地址的最后一位是仓库名,前面一位是账号。

在仓库管理中前面一位是仓库归属,很少用到,在gitee控制台才会用到;后面一位是仓库名,上传代码时使用:

git命令行推送本地分支到远程仓库_第8张图片
更多请移步官方文档

git命令行推送本地分支到远程仓库_第9张图片

回到添加远程地址,如图添加成功:

git命令行推送本地分支到远程仓库_第10张图片

  • git commit -m “info”上传版本管理的分子区,也可以说是预提交区。

这里的文件或代码将会直接提交到远程仓库,如果某些文件不是必须的,需要在提交时在gitignore文件配置需要忽视的文件。

  • git push [远程仓库名] [本地分支]:[远程仓库]将当前分支push到远程仓库

推送到远程仓库有两种存储方式:

  • 一个仓库放一个工作区文件所以可以新建文
  • 一个仓库放多个工作区文件,需要新建文件夹

只放一个文件,这种方式更新换代容易,适用于长期维护的项目:
git命令行推送本地分支到远程仓库_第11张图片
放多个文件,目录清晰,一个仓库放多个文件,可以用于放完整的项目文件:

在这里插入图片描述

一个项目的就比较容易了,直接推送即可。

放两多个文件夹的步骤如下

(1)在gitee上新建若干文件夹。

(2)将远程仓库直接克隆到本地
git命令行推送本地分支到远程仓库_第12张图片
如下图所示在本地已经有了对应的文件夹(仓库内部):
git命令行推送本地分支到远程仓库_第13张图片

(3)将需要上传的文件复制到对应目录下

git命令行推送本地分支到远程仓库_第14张图片
在最外层也就是克隆远程仓库文件夹的目录下,将所有文件推送到远程仓库:

这里需要注意的是:

  1. 克隆下来的文件需要重新绑定远程地址
  2. 远程地址为新建文件外部的仓库
  3. 代码是提交到仓库的分支上,而不是仓库中

在gitee的管理界面的我的下面可以看到属于自己的两个仓库

git命令行推送本地分支到远程仓库_第15张图片
这是我的仓库bolen,有独一无二的仓库地址https://....bolen.git,仓库是用来保存分支的。每个仓库都有一个默认的分支master

在gitee操作面板上可以看到分支,
git命令行推送本地分支到远程仓库_第16张图片
那么如何添加到指定分支呢?比如,指定添加到bolen,master,或者server分支,这里有两个决定性因素:

  • 远程仓库地址
  • 分支名称

在推送时命令是git push [远程仓库名] [本地分支]:[远程分支名],这里远程仓库名和远程分支名确定了分支的唯一性。

使用git remote add origin [brachname]后绑定了新建的仓库,在推送到推送到master分支,或新建一个分支。通过仓库名和分支名决定分支唯一性。

(4)推送本地分支到远程仓库分支

之前已经将远程仓库克隆到本地了,而且将需要上传的代码复制到相应的文件夹下,再经过上面的配置,确定定了分支的唯一性,接下来上传到远程仓库,

git命令行推送本地分支到远程仓库_第17张图片

上面红线的地方换为自己的分支名即可

如下图代码已上传到对应文件夹
git命令行推送本地分支到远程仓库_第18张图片
在该仓库中也有两个文件夹,分别为项目的前端和后端

git命令行推送本地分支到远程仓库_第19张图片

上传的到此结束了,重点在于仓库名和分支的唯一性,不然会出现各种错误。

  • git remote rm origin删除旧的远程仓库

如果父文件或当前文件远程仓库绑定错了可以删除旧文件夹再添加新建文件夹的仓库:

在这里插入图片描述

另外在推送到默认master文件夹时出现如下图错误的请移步git 上传出现“ ! [rejected] master -> master (non-fast-forward)”感谢作者!

git命令行推送本地分支到远程仓库_第20张图片

这是一个简单的提交代码的部分,在实际开发会遇到很多问题,如分支的构建与融合,代码冲突,版本回退等将在遇到实际问题时图文跟新。

你可能感兴趣的:(#,Git,git,gitee)