Git 忽略文件后,切换分支后在其它出现

huangfuyafei
  • 83

比如说我的项目有两个分支

    $ git branch
      master
    * dev

dev 分支下面有两个3个文件夹是 ignore 的: bower_components/, node_modules/, dist/.

现在我在 dev 下面提交之后, 切换到 master 分支去,结果在 master 分支下也可以看到 bower_components/, node_modules/, dist/这些目录和里面的文件,是我操作不对吗?如何解决呢?

回复
阅读 4.6k
3 个回答
✓ 已被采纳

如果这几个文件出现在版本管理中,那是因为

.gitignore 文件是在版本控制里的

dev分支下的 .gitignore 记录了你要忽略的文件
但是在master分支下, .gitigonre 还没记录下你要忽略的内容

解决方法(更新master的.gitignore)

方法1. merge dev -> master
方法2. add ignore files in .gitignore at master branch

你在一个分支修改了代码并提交,对其他分支是并无影响的。同理,你只是在 dev 分支下忽略了文件,对其他分支来说是并无影响的,所以你要做的是去其他分支重复做一遍忽略的动作,或者把 dev 分支下的修改 merge 到其他分支去。

不是你操作不正确,而是你添加到gitignore之后,git不关心这些文件了,所以切换不切换分支,这些文件都在那里

你知道吗?

宣传栏