我进行了一些更改以提交。如何查看为下一次提交准备的所有文件的差异?有一个方便的内衬吗?

gitstatus只显示暂存文件的名称,但我想查看实际的差异。

gitdiff(1)手册页显示:

git diff[--选项][--][…]此表单用于查看相对于索引所做的更改(下一次提交的暂存区域)。换句话说,这些差异是您可以告诉git进一步添加到索引中的,但您仍然没有。您可以使用gitadd(1)暂存这些更改。


当前回答

缓存对我不起作用。。。其中,灵感来自git log

gitdifforigin/<branch><branch>完成。

其他回答

从1.7版及更高版本开始,应为:

git diff --staged

对于临时区域与存储库(上次提交)的比较,请使用

$ git diff --staged

该命令将暂存的($git add fileName)更改与上次提交进行比较。如果你想看到你已经准备好了什么,然后再提交,你可以使用git diff--staged。此命令将暂存的更改与上次提交进行比较。

用于工作与暂存比较

$ git diff 

该命令将工作目录中的内容与暂存区域中的内容进行比较。需要注意的是,gitdiff本身不会显示自上次提交以来所做的所有更改 — 只有未标记的更改。如果您已经暂存了所有更改($git-add-fileName),git-diff将不会给您任何输出。

此外,如果您暂存一个文件($git-add-fileName),然后对其进行编辑,则可以使用gitdiff查看暂存文件中的更改和未暂存的更改。

如果您有多个文件进行了阶段性更改,那么使用git add-i,然后选择6:diff,最后选择您感兴趣的文件可能更实用。

默认情况下,gitdiff用于显示未添加到git更新文件列表中的更改。但是,如果您想显示添加或分段的更改,则需要提供额外的选项,让git知道您对分段或添加的文件diff感兴趣。

$ git diff          # Default Use
$ git diff --cached # Can be used to show difference after adding the files 
$ git diff --staged # Same as 'git diff --cached' mostly used with latest version of git 

实例

$ git diff 
diff --git a/x/y/z.js  b/x/y/z.js index 98fc22b..0359d84 100644
--- a/x/y/z.js 
+++ b/x/y/z.js @@ -43,7 +43,7 @@ var a = function (tooltip) {

-        if (a)
+        if (typeof a !== 'undefined')
             res = 1;
         else
             res = 2;

$ git add x/y/z.js
$ git diff
$

一旦你添加了文件,你就不能使用默认的“gitdiff”。你必须这样做:-

$ git diff --cached
diff --git a/x/y/z.js  b/x/y/z.js index 98fc22b..0359d84 100644
    --- a/x/y/z.js 
    +++ b/x/y/z.js @@ -43,7 +43,7 @@ var a = function (tooltip) {

    -        if (a)
    +        if (typeof a !== 'undefined')
                 res = 1;
             else
                 res = 2;

还可以考虑一下gitk工具,它随git一起提供,对查看更改非常有用