前言
在使用Git这个多人协作的代码版本控制工具时,为了避免每次提交修改代码时,一些预期外的无用文件的改动同时被提交并加入版本控制,需要将一些和代码无关的无用文件排除在版本控制外,此时也就需要使用.gitignore文件来指定这些需要忽略的文件信息。
不同类型的工程都有一些通用的.gitignore范本,一般在项目初始化以后,直接按照范本加入.gitignore文件即可,这些使用.gitignore文件指定的忽略文件是不会被推送到远程仓库的,在以后的coding中就不用再关心这些被忽略的文件了。
问题
-
已经初始化项目了,并配置.gitignore文件了,可以另外追加忽略文件么?
直接追加进.gitignore文件忽略文件列表就可以了。
-
已经加入.gitignore文件列表的被忽略文件,想要进行改动,并提交推送到远程仓库,要如何做?
只需要将被忽略的文件类型从.gitignore列表移除或注释掉,再次修改原来被忽略类型的文件时,就会提示此类文件被修改,需要加入版本控制了。
-
原来被忽略的文件,取消忽略后,可以重新加入忽略么?
可以,同样只需要再次追加进.gitignore文件忽略文件列表就可以了。
分隔线
真相
-
上文中的问题1、2、3会生效么?
2会立即生效,1和3会出现失效的情况。
-
1和3为什么会出现失效的情况?
这是由于gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。
-
怎么解决1和3失效的情况
先把本地缓存删除(改变成未track状态),然后再提交
git rm -r --cached . git add . git commit -m 'commit log info'