之前说过Git与IDEA的强强结合(HTTPS协议连接)那么如何使用命令行来推送代码呢?
下图是基于layui的前端代码:
目录工作区文件:
本地内容就是将这些内容推送到远程仓库
首先使用git命令初始化git本地仓库:
git init
创建本地仓库
以出现.git
命令为参考:
创建git仓库后vs code也有颜色的变化:
除了颜色的变化外还有字母呢U
,它们的含义是:
红色,未加入版本控制;
绿色,已经加入版本控制暂未提交;
蓝色,加入版本控制,已提交,有改动;
白色,加入版本控制,已提交,无改动;
灰色:版本控制已忽略文件。
git文件标识:
A: 增加的文件.
C: 文件的一个新拷贝.
D: 删除的一个文件.
M: 文件的内容或者mode被修改了.
R: 文件名被修改了。
T: 文件的类型被修改了。
U: 文件没有被合并
X: 未知状态
然后绑定用户名和邮箱,方便记录提交者信息:
git config --global user.name
和git config --global user.email
将需要提交的文件或代码提交到暂存区:
git add
将文件添加到缓存区
如果之前选择在根目录的上级创建git仓库的话使用 git add [dir]
dir为路径添加到缓存区,或者使用git add filename
添加指定目录至缓存区。如果是在根目录内部,直接git add .
将当前更改文件添加到缓存区,如下图所示:
warning: LF will be replaced by CRLF
出现该警告的原因是不同系统下的换行符不一样,只需了解即可,git会自动检测系统内核,将换行符自动转换,具体了解请移步IDEA和VS代码设置默认换行符为LF感谢作者!
由于git推送的时候会自动转换,所以可以直接统一格式,简单多了。这取决于您使用的系统。对于 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 remote add origin [远程仓库地址]
添加远程仓库
git remote -v
查看远程仓库路径
git remote add origin [addr]
添加远程仓库
登录gitee,选择仓库,复制仓库地址,在命令行添加
https地址的地址的最后一位是仓库名,前面一位是账号。
在仓库管理中,第一个数字是仓库所有权,很少使用,仅在gitee控制台中使用;最后一位是仓库名称,上传代码时使用:
更多请移步官方文档
返回添加远程地址,如图,添加成功:
git commit -m “info”
上传版本管理的分子区,也可以说是预提交区。
这里的文件或代码将会直接提交到远程仓库,如果某些文件不是必须的,需要在提交时在gitignore
文件配置需要忽视的文件。
git push [远程仓库名] [本地分支]:[远程仓库]
将当前分支push到远程仓库
推送到远程仓库有两种存储方式:
- 仓库包含工作区文件,以便您可以创建新文件
- 如果要在一个仓库中存储多个工作区文件,需要新建一个文件夹。
只放一个文件,这种方式更新换代容易,适用于长期维护的项目:
放多个文件,目录清晰,一个仓库放多个文件,可以用于放完整的项目文件:
对于一个项目来说比较简单,直接push就可以了。
放置两个或多个文件夹的步骤如下
(1)在gitee上新建几个文件夹。
(2)将远程仓库直接克隆到本地
如下图所示在本地已经有了对应的文件夹(仓库内部):
(3)将需要上传的文件复制到对应目录
在最外层也就是克隆远程仓库文件夹的目录下,将所有文件推送到远程仓库:
这里需要注意的是:
- 克隆的文件需要重新绑定远程地址
- 远程地址是新创建的文件之外的仓库。
- 代码提交到仓库的分支,而不是仓库
在gitee管理界面的me下,可以看到两个属于你的仓库。
这是我的仓库bolen
,有独一无二的仓库地址https://....bolen.git
,仓库是用来保存分支的。每个仓库都有一个默认的分支master
。
在gitee操作面板上可以看到分支,
那么如何添加到指定分支呢?比如,指定添加到bolen,master,或者server分支,这里有两个决定性因素:
- 远程仓库地址
- 分店名称
在推送时命令是git push [远程仓库名] [本地分支]:[远程分支名]
,这里远程仓库名和远程分支名确定了分支的唯一性。
使用git remote add origin [brachname]
后绑定了新建的仓库,在推送到推送到master
分支,或新建一个分支。通过仓库名和分支名决定分支唯一性。
(4)将本地分支push到远程仓库分支
之前已经将远程仓库克隆到本地,将要上传的代码复制到对应的文件夹中。经过上述配置后,分支的唯一性已经确定,然后上传到远程仓库。
只需将上面的红线替换为您自己的分支名称即可。
如下图代码已上传到对应文件夹
在该仓库中也有两个文件夹,分别为项目的前端和后端
至此上传结束。关键是仓库名称和分支要唯一,否则会出现各种错误。
git remote rm origin
删除旧的远程仓库
如果父文件或当前文件的远程仓库绑定错误,可以删除旧文件夹,然后添加新文件夹的仓库:
另外在推送到默认master
文件夹时出现如下图错误的请移步git上传时出现“![rejected] master -> master (non-fastforward)”感谢作者!
这是提交代码的简单部分。在实际开发中,会遇到很多问题,比如分支构建和集成、代码冲突、版本回滚等,图文会在遇到实际问题时更新。