92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线

讓你的 commit 更有價值

2020-7-29    seo達人

提交規范

AngularJS 在開發者文檔中關于 git commit 的指導說明,提到嚴格的 git commit 格式規范可以在瀏覽項目歷史的過程中看到更易讀的信息,并且能用 git commit 的信息直接生成 AngularJS 的 change log 。


commit messages 格式規范

commit messages 由 header 、body 、footer 組成。


header 又包含 type 、scope 、subject 。header 是必需的,不過其中的 scope 是可選的。


body 和 footer 可以省略。


<type>(<scope>): <subject>

// 空行

<BLANK LINE>

<body>

// 空行

<BLANK LINE>

<footer>

注:為了能在 github 以及各種 git 工具中看得更清晰,commit messages 的每一行都不要超過 100 個字符。

Header

Type

類型必須是以下幾種之一:


feat: 新功能

fix: bug 修復

docs: 僅修改文檔

style: 修改格式(空格,格式化,省略分號等),對代碼運行沒有影響

refactor: 重構(既不是修 bug ,也不是加功能)

build: 構建流程、外部依賴變更,比如升級 npm 包、修改 webpack 配置等

perf: 性能優化

test: 測試相關

chore: 對構建過程或輔助工具和庫(如文檔生成)的更改

ci: ci 相關的更改

除此之外,還有一個特殊的類型 revert ,如果當前提交是為了撤銷之前的某次提交,應該用 revert 開頭,后面加上被撤銷的提交的 header,在 body 中應該注明: This reverts commit <hash>. ,hash 指的就是將要被撤銷的 commit SHA 。


// 例如


revert: feat(user): add user type


This reverts commit ca16a365467e17915f0273392f4a13331b17617d.

Scope

scope 可以指定提交更改的影響范圍,這個視項目而定,當修改影響超過單個的 scope 時,可以指定為 * 。


Sbuject

subject 是指更改的簡潔描述,長度約定在 50 個字符以內,通常遵循以下幾個規范:


用動詞開頭,第一人稱現在時表述,例如:change 代替 changed 或 changes

第一個字母小寫

結尾不加句號(.)

Body

body 部分是對本地 commit 的詳細描述,可以分成多行。


跟 subject 類似,用動詞開頭,第一人稱現在時表述,例如:change 代替 changed 或 changes。


body 應該說明修改的原因和更改前后的行為對比。


Footer

footer 基本用在這兩種情況:


不兼容的改動( Breaking Changes ),通常用 BREAKING CHANGE: 開頭,后面跟一個空格或兩個換行符。剩余的部分就是用來說明這個變動的信息和遷移方法等。

關閉 Issue, github 關閉 Issue 的例子

// BREAKING CHANGE: 的例子

BREAKING CHANGE: isolate scope bindings definition has changed and

   the inject option for the directive controller injection was removed.


   To migrate the code follow the example below:


   Before:


   scope: {

     myAttr: 'attribute',

     myBind: 'bind',

     myExpression: 'expression',

     myEval: 'evaluate',

     myAccessor: 'accessor'

   }


   After:


   scope: {

     myAttr: '@',

     myBind: '@',

     myExpression: '&',

     // myEval - usually not useful, but in cases where the expression is assignable, you can use '='

     myAccessor: '=' // in directive's template change myAccessor() to myAccessor

   }


   The removed `inject` wasn't generaly useful for directives so there should be no code using it.




// Closes Issue 例子

Closes #2314, #3421

完整的例子

例一: feat

feat($browser): onUrlChange event (popstate/hashchange/polling)


Added new event to $browser:

- forward popstate event if available

- forward hashchange event if popstate not available

- do polling when neither popstate nor hashchange available


Breaks $browser.onHashChange, which was removed (use onUrlChange instead)

例二: fix

fix($compile): couple of unit tests for IE9


Older IEs serialize html uppercased, but IE9 does not...

Would be better to expect case insensitive, unfortunately jasmine does

not allow to user regexps for throw expectations.


Closes #392

Breaks foo.bar api, foo.baz should be used instead

例三: style

style($location): add couple of missing semi colons

查看更多例子

規范 commit message 的好處

首行就是簡潔實用的關鍵信息,方便在 git history 中快速瀏覽

具有詳實的 body 和 footer ,可以清晰的看出某次提交的目的和影響

可以通過 type 過濾出想要查找的信息,也可以通過關鍵字快速查找相關提交

可以直接從 commit 生成 change log

// 列舉幾個常用的 log 參數


// 輸出 log 的首行

git log --pretty=oneline


// 只輸出首行的 commit 信息。不包含 hash 和 合并信息等

git log --pretty=format:%s


// 查找有關“更新菜單配置項”的提交

git log --grep="更新菜單配置項"


// 打印出 chenfangxu 的提交

git log --author=chenfangxu


// 紅色的短 hash,黃色的 ref , 綠色的相對時間

git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr)%Creset'

用工具實現規范提交

上面介紹了規范提交的格式,如果讓各位同學在 git commit 的時候嚴格按照上面的規范來寫,首先心智是有負擔的,得記住不同的類型到底是用來定義什么的,subject 怎么寫,body 怎么寫,footer 要不要寫。其次,對人的規范大部分都是反人性的,所以很可能在過不了多久,就會有同學漸漸的不按照規范來寫??恳庵玖砜刂谱约簢栏癜凑找幏秮韺懯切枰~外耗費一些精力的,把精力耗費在這種事情上面實在有些浪費。


用工具實現規范提交的方案,一種是在提交的時候就提示必填字段,另一種是在提交后校驗字段是否符合規范。這兩種在實際項目中都是很有必要的。


Commitizen

Zen-like commit messages for internet citizens. 嗯~~一種禪意

Commitizen 是一個幫助撰寫規范 commit message 的工具。他有一個命令行工具 cz-cli,接下來會把使用 Commitizen 分成幾個階段來介紹。


體驗 git cz

// 全局安裝 Commitizen

npm install -g commitizen

你的倉庫可能還不是對 Commitizen 友好的,此時運行 git cz 的效果跟 git commit 一樣,也就是沒有效果。 不過,可以執行 npx git-cz 來體驗。


如果想直接運行 git cz 實現語義化的提交,可以根據 streamich/git-cz 文檔中說的全局安裝 git cz。


// 全局安裝 git cz

npm install -g git-cz

除此之外還有一種更推薦的方式,就是讓你的倉庫對 Commitizen 友好。


Commitizen 友好

全局安裝 Commitizen 后,用 cz-conventional-changelog 適配器來初始化你的項目


// 初始化 cz-conventional-changelog 適配器

commitizen init cz-conventional-changelog --save-dev --save-exact

上面的初始化做了三件事:


安裝 cz-conventional-changelog 依賴

把依賴保存到 package.json 的 dependencies 或 devDependencies 中

在根目錄的 package.json 中 添加如下所示的 config.commitizen

"config": {

   "commitizen": {

     "path": "./node_modules/cz-conventional-changelog"

   }

 }

或者,在項目根目錄下新建一個 .czrc 文件,內容設置為


{

 "path": "cz-conventional-changelog"

}

現在運行 git cz 效果如下:




cz-customizable 自定義中文配置

通過上面的截圖可以看到,提交的配置選項都是英文的,如果想改成中文的,可以使用 cz-customizable 適配器。


運行下面的命令,注意之前已經初始化過一次了,這次再初始化,需要加 --force 覆蓋


npm install cz-customizable --save-dev


commitizen init cz-customizable --save-dev --save-exact --force

現在 package.json 中 config.commitizen 字段為:


"config": {

   "commitizen": {

     "path": "./node_modules/cz-customizable"

   }

 }

cz-customizable 文檔中說明了查找配置文件的方式有三種,我們按照第一種,在項目根目錄創建一個 .cz-config.js 的文件。按照給出的示例 cz-config-EXAMPLE.js 編寫我們的 config。 commit-type 可以參考 conventional-commit-types 。


可以點擊查看我配置好的文件 qiqihaobenben/commitizen-git/.cz-config.js ,里面中詳細的注釋。


commitlint 校驗提交

Commitizen 文檔中開始就介紹到,Commitizen 可以在觸發 git commit 鉤子之前就能給出提示,但是也明確表示提交時對 commit messages 的校驗也是很有用的。畢竟即使用了 Commitzen,也是能繞過去,所以提交最后的校驗很重要。


commitlint 可以檢查 commit messages 是否符合常規提交格式,需要一份校驗配置,推薦 @commitlint/config-conventional 。


npm i --save-dev @commitlint/config-conventional @commitlint/cli

在項目根目錄創建 commitlint.config.js 文件并設置校驗規則:


module.exports = {

 extends: ["@commitlint/config-conventional"],

 // rules 里面可以設置一些自定義的校驗規則

 rules: {},

};

在項目中安裝 husky ,并在項目根目錄新建 husky.config.js 文件,加入以下設置:


// 安裝 husky

npm install --save-dev husky



// husky.config.js 中加入以下代碼

module.exports = {

 "hooks": {

   "commit-msg": "commitlint -E HUSKY_GIT_PARAMS"

 }

}

注意:因為 @commitlint/config-conventional 校驗規則遵循 Angular 的規范, 所以我們在用 cz-customizable 自定義中文配置時, 是按照給出的符合 Angular 規范的示例 cz-config-EXAMPLE.js 編寫.cz-config.js 的。但是如果你自定義的 Commitizen 配置不符合 Angular 規范,可以使用 commitlint-config-cz 設置校驗規則。(推薦還是按照 Angular 規范進行 cz-customizable 自定義配置)

// 安裝 commitlint-config-cz

npm install commitlint-config-cz --save-dev



// commitlint.config.js 改為

module.exports = {

 extends: [

   'cz'

 ]

};

git commit 觸發 git cz

在提交的時候,我們都習慣了 git commit ,雖然換成 git cz 不難,但是如果讓開發者在 git commit 時無感知的觸發 git cz 肯定是更好的,

而且也能避免不熟悉項目的人直接 git commit 提交一些不符合規范的信息。


我們可以在 husky.config.js 中設置:


"hooks": {

 "prepare-commit-msg": "exec < /dev/tty && git cz --hook || true",

}

注意: 在 window 系統,可能需要在 git base 中才能生效。

生成 CHANGELOG

standard-version

是一個使用 semver 和 conventional-commits 支持生成 CHANGELOG 進行版本控制的實用程序。

standard-version 不只是能生成 CHANGELOG , 還能根據 commit 的 type 來進行版本控制。


// 安裝 standard-verison

npm i --save-dev standard-version


// 在 package.json 中的 scripts 加入 standard-version

{

 "scripts": {

   "release": "standard-version"

 }

}

示例項目

可以查看 commitizen-git ,里面歸納了快速配置 Commitizen 友好倉庫的步驟。

差不多三五分鐘就能搞定。


可以看一下配置完后,執行 git commit 的效果。




擴展

更復雜的自定義提示

cz-customizable 中自定義配置項通常情況是夠用的,

commitlint 中校驗的規則基本上也是夠用的,但是會有比較硬核的開發者會覺得還是不夠,還要更多。比如一些 prompt 更加自定義,

提交時詢問的 question 添加更多的邏輯,比如可以把一些重要的字段校驗提前到 Commitizen 中,或者添加更多自定義的校驗。


如果真想這么干,那就去 fork 一份 cz-conventional-changelog 或者 cz-customizable 來改,

或者直接自己寫一個 adapter。


Commitizen 友好徽章

如果把倉庫配置成了對 Commitizen 友好的話,可以在 README.md 中加上這個小徽章

藍藍設計m.skdbbs.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務

日歷

鏈接

個人資料

藍藍設計的小編 http://m.skdbbs.com

存檔

92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线
亚洲不卡av不卡一区二区| 91亚洲精品在看在线观看高清| 91精品国产调教在线观看| 国产精品扒开腿做爽爽爽视频软件| h视频在线观看免费| 欧洲s码亚洲m码精品一区| 亚洲永久精品大片| 成人aaaa| 国产乱码精品一区二三赶尸艳谈| 成人午夜免费电影| 亚洲伊人影院| 久久99国产精品久久99| 大胆av不用播放器在线播放| 美女性感视频久久久| 亚洲综合色站| 精品日本一区二区三区在线观看| 99久久综合狠狠综合久久| 欧美日韩另类综合| 久久久久久a亚洲欧洲aⅴ| 国产乱码精品一区二三赶尸艳谈| 俺来俺也去www色在线观看| 亚洲成人三级| 国产精品qvod| 日韩精品每日更新| 日韩网站在线观看| 大胆欧美人体视频| 欧美精品久久久久久| 精品国产综合久久| 午夜久久久久久久久久一区二区| 99精品综合| 亚洲大胆美女视频| 91一区二区三区在线播放| 欧美日韩电影免费看| 日本精品国语自产拍在线观看| 亚洲精品中文在线观看| 午夜精品福利在线| 亚洲盗摄视频| 一个色综合网站| 欧美天堂在线观看| 美女网站视频久久| 五月综合激情网| 亚洲图片欧美视频| 国产美女撒尿一区二区| 国产在线一区二区视频| 在线成人免费视频| 免费一级欧美片在线观看| 欧美韩国一区| 久久99精品国产麻豆婷婷洗澡| 男人天堂久久| 久久久亚洲精品视频| 欧洲精品中文字幕| 91久久精品美女| 国产三级精品在线不卡| 精品久久久免费| 狠狠色综合网| 成人激情av网| 高清欧美性猛交xxxx| 日本中文在线一区| 国产精品自拍视频| 亚洲小说欧美另类社区| 无码免费一区二区三区免费播放| 国模一区二区三区| 日韩高清中文字幕| 国产做受高潮69| 成人国产精品久久久久久亚洲| 欧美独立站高清久久| 精品国产乱码久久久久久郑州公司| 日本肉肉一区| 日韩电影在线免费| 国产成人小视频| 影音先锋中文在线视频| 国产尤物一区二区| 91久久夜色精品国产九色| 日韩欧美国产一区在线观看| 天天免费亚洲黑人免费| 亚洲美腿欧美偷拍| 久久香蕉av| 欧美激情videos| 中文字幕字幕中文在线中不卡视频| 欧美日韩一区在线观看视频| 精品久久一二三区| 亚洲精品中文字幕有码专区| 色黄网站在线观看| 欧美与黑人午夜性猛交久久久| 青草成人免费视频| 美女av一区二区| 九九精品视频在线观看| 91福利精品第一导航| 精品视频免费看| 羞羞影院欧美| 日韩一区二区三区视频在线| av电影在线观看不卡| 高清欧美性猛交xxxx黑人猛| 最新真实国产在线视频| 欧美日韩一区二区三区高清| 在线精品视频免费观看| 少妇精品视频一区二区免费看| 久久九九电影| 国产亚洲欧美一区二区| 成人一区在线看| 中文字幕欧美日本乱码一线二线| 国产成人在线精品| 蜜臀av一区二区在线免费观看| 亚洲国产最新| 亚洲天堂网中文字| 亚洲国产成人av好男人在线观看| 日韩一区二区精品葵司在线| 精品伦理一区二区三区| 精品亚洲国产视频| 一区二区福利视频| 亚洲欧美综合久久久| 成人片免费看| 成人国产一区二区| 91麻豆免费视频| 久久精品视频免费播放| 一区二区三区日韩欧美精品| 亚洲欧洲一区二区三区在线观看| 成人免费在线观看视频| 51精品视频一区二区三区| 亚洲**毛片| 国产视频精品自拍| 亚洲成人黄色影院| 欧美mv日韩mv| 国产婷婷精品av在线| 久久艳片www.17c.com| 欧美少妇一区二区| 免费精品国产的网站免费观看| 亚洲国产成人porn| 欧美调教sm| 亚洲自拍av在线| 美乳视频一区二区| 日韩免费在线免费观看| 亚洲欧美专区| 91小视频xxxx网站在线| 国产99久久精品一区二区| 国产精品二区三区四区| 欧美激情综合亚洲一二区| 日韩精品一区二区三区免费视频| 在线精品一区| 日韩欧美亚洲国产另类| 亚洲欧洲在线免费| 欧美精品日日操| 狠狠色综合一区二区| 欧美日韩亚洲系列| 日韩视频一区在线观看| 欧美体内she精视频在线观看| 亚洲国产女人aaa毛片在线| 自拍偷拍亚洲欧美日韩| 精品国产乱码久久久久久1区2匹| 国产成人在线看| 97久久伊人激情网| 免费av在线一区二区| 成人无遮挡免费网站视频在线观看| 久久精品久久久久电影| 91精品国产黑色紧身裤美女| 亚洲高清在线视频| 91久久精品国产91久久性色tv| 97精品国产一区二区三区| 久久一区二区三区欧美亚洲| 色婷婷亚洲一区二区三区| 高h视频在线播放| 国产日韩精品视频| 欧美激情专区| yy6080久久伦理一区二区|