.gitignore檔案是幹什麼的

語言: CN / TW / HK

theme: devui-blue

本節課我們學習下.gitignore檔案

在本地的程式碼目錄中,有些檔案或者目錄我們並不想提交到倉庫中,比如一些執行日誌等檔案。這樣的話,我們提交程式碼時,就只能一個一個檔案去git add,太麻煩了。

為了解決這個問題,Git裡面有一個.gitignore檔案。可以指定Git需要忽略哪些檔案。配置好之後,Git就會自動忽略滿足配置的檔案。這樣,我們就可以盡情的使用git add .來新增檔案了。

Git 忽略規則優先順序

.gitingore 檔案中,每一行指定一個忽略規則,Git 檢查忽略規則的時候有多個來源,它的優先順序如下(由高到低): 1. 從命令列中讀取可用的忽略規則 2. 當前目錄定義的規則 3. 父級目錄定義的規則,依次遞推 4. $GIT_DIR/info/exclude 檔案中定義的規則 5. core.excludesfile中定義的全域性規則

Git 忽略規則匹配語法

.gitignore 檔案中,每一行的忽略規則的語法如下: - 空格不匹配任意檔案,可作為分隔符,可用反斜槓轉義 - 開頭的檔案標識註釋,可以使用反斜槓進行轉義 - !開頭的模式標識否定,該檔案將會再次被包含,如果排除了該檔案的父級目錄,則使用!也不會再次被包含。可以使用反斜槓進行轉義 - /結束的模式只匹配資料夾以及在該資料夾路徑下的內容,但是不匹配該檔案 - /開始的模式匹配專案跟目錄 - 如果一個模式不包含斜槓,則它匹配相對於當前.gitignore檔案路徑的內容,如果該模式不在.gitignore檔案中,則相對於專案根目錄 - ** 匹配多級目錄,可在開始,中間,結束 - ? 通用匹配單個字元 - * 通用匹配零個或多個字元 - [] 通用匹配單個字元列表

匹配示例

  • bin/: 忽略當前路徑下的bin資料夾,該資料夾下的所有內容都會被忽略,不忽略bin檔案
  • /bin: 忽略根目錄下的bin檔案
  • /*.c: 忽略 cat.c,不忽略 build/cat.c
  • debug/*.obj: 忽略 debug/io.obj,不忽略 debug/common/io.objtools/debug/io.obj
  • **/foo: 忽略/foo, a/foo, a/b/foo
  • a/**/b: 忽略a/b, a/x/b, a/x/y/b
  • !/bin/run.sh: 不忽略 bin 目錄下的 run.sh 檔案
  • *.log: 忽略所有 .log 檔案
  • config.php: 忽略當前路徑的 config.php 檔案

特殊情況

檔案已經提交過

這裡面有一些特殊情況需要考慮,比如某檔案已經被提交過了,之後再對他做了一個.gitignore的忽略的話。忽略是不會生效的,需要我們手動先將快取刪除。 ```shell

刪除本地的快取

git rm -r --cached .

重新提交

git commit -am 'gitignore' ```

新增一個已經配置忽略的檔案

再比如,我們忽略了資料夾A,但是現在要往資料夾A中新增程式碼檔案。你會發現你沒法把資料夾A中的程式碼提交。因為資料夾A被忽略了。 ```shell

強制新增

git add -f 檔案A/xxx.js

正常提交

git commit -am 'xxx' ```

檢查檔案為什麼被忽略

由於.gitignore檔案經常會配置很多內容,某些檔案你並不能很直觀的知道為什麼被忽略了。所以Git提供了一個檢查忽略的命令。 shell git check-ignore -v 資料夾A/xxx.js

gitignore建議

最後,提供一個網上整理的關於不同開發語言專案的.gitignore檔案內容的建議:https://github.com/github/gitignore

開啟掘金成長之旅!這是我參與「掘金日新計劃 · 2 月更文挑戰」的第 15 天,點選檢視活動詳情