你们好,今天咱们来介绍git当中一项很是重要的功能——交互式工具git
有的时候若是咱们要处理的文件不少,使用git add .等操做会很是有隐患,由于颇有可能咱们一不当心就疏忽了一些内容。若是咱们使用一个文件名一个文件名地填写呢,又很是地复杂,体验并很差。因此呢git当中还提供了第三种方法,也就是今天要介绍的内容——交互式工具。web
交互式暂存的命令很是简单,其实就是一个参数,-i。这里的i表示的是interactive,也就是交互的意思。当咱们执行这个命令以后,git会进入一个交互式的终端。这样咱们就能够经过一些简短地命令和git进行交互。vim
首先,咱们输入git add -i 进入交互式的命令。编辑器
能够看到这里有8个选项,这里的选项你们应该都能看懂,其中集成了不少种功能,咱们接下来一个一个讲解。工具
首先是将新文件添加到暂存区,咱们选择4,表示添加未被git管理的文件,接着又会询问咱们要添加的文件。这里咱们就不用再输入文件名了,直接选择序号便可。咱们先添加一个,选择3。以后咱们会看到3对应的文件名前面被打上了*,表示这个文件将会被添加。测试
接着咱们再敲一次回车,能够回到上级菜单,而后咱们选择7退出,能够看到git的状态已经改变了。flex
咱们将改动添加到暂存区以后,咱们还可使用git add -i 来查看某一个文件的具体改动。操做方法也很是简单,咱们一样经过git add -i 进入交互模式,而后选择6进入diff模式。spa
接着咱们输入1,表示咱们要查看的改动,git会打开一个vim窗口,为咱们展现这个文件当中被咱们添加的改动。3d
它的效果等价于咱们执行git diff --cached。orm
若是咱们add了以后,发现add错了,想要反悔,那么也是容易的,咱们可使用revert功能撤销咱们此次的add。
操做也很简单,咱们仍是输入git add -i 进入交互式的命令。会发现咱们刚进来的时候就提示咱们当前暂存区的状态。这里咱们选择3进行撤销,git会展现出咱们暂存区的全部文件,这里咱们只提交了一个文件,因此也只能看到一个。
这里咱们选择1号文件,而后退出,会发现咱们回到了git提交以前的状态。
最后介绍一下补丁的功能,这个功能我用的很少,不过用好了能够在一些状况下大大简化咱们的操做。
当咱们执行暂存操做的时候,咱们针对的主体都是某一个文件。可是会有这样一种状况,某一个文件当中的改动不少,咱们只想要把其中的一部分添加进git,另一部分先保留在本地。这种状况也很常见,好比同时开发两个功能,一个开发好了,另一个还在测试。为了赶工期,决定先把其中的一个功能先上线,那么还在测试的功能显然不能被提交,不然可能会带来隐患。
针对这种状况,咱们就须要使用补丁。为了演示,咱们在以前的文件当中加了两行废话,而后执行git add -i,选择5.
当咱们选择了咱们想要进行补丁的文件而且按回车以后,git会把咱们的改动一个部分一个部分地询问咱们。
这里的命令可能看不明白,不要紧,咱们输入?能够获取完整的含义。
说了这么多,其实关键的只有两个,y表示须要把它加入存储,n表示不加入。这样当咱们操做完了以后,咱们再来查看状态,会发现刚才咱们操做过的文件当中,一部分被添加了进来,另一部分没有。
怎么样,交互式命令是否是很是好用呢?
它的最大的一个优势就是将多个命令集合在了一块儿,能够一个命令实现多个功能。而且每一个功能都以交互的形式展示,能够方便咱们的操做,下降咱们搞错的概率。这也是不少git大神很是喜欢的功能,但愿你们都能学会。
今天的文章就到这里,衷心祝愿你们天天都有所收获。若是还喜欢今天的内容的话,请来一个三连支持吧~(点赞、关注、转发)
{{uploading-image-87920.png(uploading...)}}