当前位置: 代码迷 >> 综合 >> .gitignore 文件不生效问题 & 解决方法
  详细解决方案

.gitignore 文件不生效问题 & 解决方法

热度:13   发布时间:2024-02-12 16:21:52.0

文章目录

      • 问题
      • 解决方法
      • git库文件夹中文件的几种状态

问题

在 .gitignore 文件中已经写入了要忽略的文件和目录,git push 的时候还会出现在 push 的目录中,在GitHub上还是出现此类文件,用 git status 查看状态,想要忽略的文件还是显示被追踪状态。

tips:

  • 这个文件的完整文件名就是 “.gitignore”,此文件没有其他后缀 .txt 等,且最前面有个 “.”
  • 如果在创建.gitignore文件之前就 push了项目,后面即使写了.gitignore文件进行忽略,文件也不会起作用,Git 仍然会对所有文件进行管理。此问题可以简单理解成,Git 已经开始管理这些文件了,所以无法再通过过滤规则过滤它们。
  • gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。想要.gitignore起作用,必须要在这些文件不在暂存区中才可以,.gitignore文件只是忽略没有被staged(cached)文件,对于已经被staged文件,加入ignore文件时一定要先从staged移除,才可以忽略。

解决方法

先删除缓存(将所有文件变成 untracked 的状态),再进行git的提交

  • git rm -r --cached .清除本地 git 缓存,改变成未track状态
  • git add .将文件提交至暂存区
  • git commit -m "清除git缓存,解决gitignore问题"
  • git push提交至远程仓库

git库文件夹中文件的几种状态

  • Untracked
    未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged。
  • Staged
    暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致
  • Unmodified
    文件已经入库,未修改,即版本库中的文件内容与文件夹中完全一致。此类型的文件有两种去处,如果被修改变为Modified;如果使用 git rm 移出版本库,则成为Untracked文件。
  • Modified
    文件已修改,仅是修改,并没进行其他操作。这个文件也有两个去处, 通过 git add 加入暂存 staged 状态;使用git checkout 则丢弃此修改,返回到 unmodified 状态,这个 git checkout 即从库中取出文件, 覆盖当前修改。

untracked 和 not staged的区别:

  • untrack 表示是新文件,没有被add过,是为跟踪的意思。
  • not staged 表示 add 过的文件,即跟踪文件,再次修改此文件后就变成没有 add 的文件,就是没有暂存的意思。

参考文章如下,非常感谢!
文章1
文章2

  相关解决方案