掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
最近被同事吐槽了,說我代碼提交說明寫的太差。其實都不用他吐槽,我自己心里也非常清楚。畢竟很多時候犯懶,都是直接一個 -m "fix" 就提交上去了。

專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)沙河免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
這樣做是非常不好的,我也是自食惡果,深受其害。特別是查看歷史提交記錄時,想通過提交說明來了解當(dāng)時的功能變更,基本不可能,都得點進去看代碼才行。
所以這兩天看了一些如何寫好提交說明的資料,系統(tǒng)地學(xué)習(xí)了一下。雖然團隊沒有這方面的要求,但是想要進步,得對自己提更高的要求才行。
一般使用 git 提交代碼的話,可以使用 -m 參數(shù)來指定提交說明,比如:
$ git commit -m "hello world"
如果一行不夠,可以只執(zhí)行 git commit,這樣就會跳出文本編輯器來寫多行:
$ git commit
Commit Message 包括三個部分:Header,Body 和 Footer。
其中,Header 是必需的,Body 和 Footer 可以省略。
Header 部分只有一行,包括三個字段:type(必需)、scope(可選)、subject(必需)。
( ):
type 用于說明 commit 的類別,具體的標(biāo)識如下:
scope 用于說明 commit 的影響范圍,比如數(shù)據(jù)層、控制層、視圖層等等,視項目不同而不同。
如果你的修改影響了不止一個 scope,就可以使用 * 代替。
subject 是 commit 目的的簡單描述,不超過 50 個字符,結(jié)尾不需要句號。
Body 部分是對本次 commit 的詳細描述,可以分多行。
Body 部分應(yīng)該說明代碼變動的動機,以及與以前行為的對比。
More detailed explanatory text, if necessary. Wrap it to
about 72 characters or so.
Further paragraphs come after blank lines.
- Bullet points are okay, too
- Use a hanging indent
Footer 部分主要用于兩種情況:不兼容變動和處理 Issue。
如果當(dāng)前代碼與上一個版本不兼容,則 Footer 部分以 BREAKING CHANGE: 開頭,后面就是對變動的描述、以及變動理由和遷移方法。
BREAKING CHANGE: Previously, $compileProvider.preAssignBindingsEnabled was set to true by default. This means bindings were pre-assigned in component constructors. In Angular 1.5+ the place to put the initialization logic relying on bindings being present is the controller $onInit method.
To migrate follow the example below:
Before:
```js
angular.module('myApp', [])
.component('myComponent', {
bindings: {value: '<'},
controller: function() {
this.doubleValue = this.value * 2;
}
});
```
After:
```js
angular.module('myApp', [])
.component('myComponent', {
bindings: {value: '<'},
controller: function() {
this.$onInit = function() {
this.doubleValue = this.value * 2;
};
};
this.doubleValue = this.value * 2;
}
});
```
Don't do this if you're writing a library, though, as you shouldn't change global configuration then.
處理 Issue 分為兩種情況,分別是關(guān)聯(lián) Issue 和關(guān)閉 Issue。
比如本次提交如果和某個 issue 有關(guān)系:
Issue #1, #2, #3
如果當(dāng)前提交信息解決了某個 issue:
Close #1, #2, #3
還有一種特殊情況,如果當(dāng)前 commit 用于撤銷以前的 commit,則必須以 revert: 開頭,后面跟著被撤銷 commit 的 Header。
revert: feat(pencil): add 'graphiteWidth' option
This reverts commit 667ecc1654a317a13331b17617d973392f415f02.
Body 部分的格式是固定的,必須寫成 This reverts commit <hash>.,其中 hash 是被撤銷 commit 的 SHA 標(biāo)識符。
如果當(dāng)前 commit 與被撤銷的 commit,在同一個發(fā)布(release)里面,那么它們都不會出現(xiàn)在 Change log 里面。如果兩者在不同的發(fā)布,那么當(dāng)前 commit,會出現(xiàn)在 Change log 的 Reverts 小標(biāo)題下面。
最后來看一個例子,算是一個總結(jié),至于具體內(nèi)容還是要根據(jù)實際情況來填寫。
feat: 添加了分享功能
給每篇博文添加了分享功能
- 添加分享到微博功能
- 添加分享到微信功能
- 添加分享到朋友圈功能
Issue #1, #2
Close #1
有了這些規(guī)范,也知道怎么寫了,但是不是會擔(dān)心記不住呢?不要怕,有插件可以用,如果使用 VsCode 的話,可以安裝一個叫 Commit Message Editor 的插件。
可以根據(jù)提示信息直接寫:
也可以使用表單的方式,有選項可以選擇:
這樣不僅可以很方便地寫提交說明了,還可以使提交說明更加的規(guī)范。
以上就是本文的全部內(nèi)容,如果覺得還不錯的話歡迎點贊,轉(zhuǎn)發(fā)和關(guān)注,感謝支持。
參考文章:

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流