一、目的
无规矩不成方圆,当查看git提交历史的时候,发现每个人git的提交记录都有自己的风格和习惯,并没有一套完整的规范,不利于阅读和维护。所以需要一套git提交规范,使得提交记录清晰明了,让人一看就能知道此次提交的目的。
二、业界比较认可和常用的规范
三部分组成:header(关键)、body(可省略)、footer(可省略)
建议这三个部分,每个部分的字符都不要超过100字符,避免自动换行影响美观
// 头header
<type>(<scope>): <subject>
// 空一行
<body>
// 空一行
<footer>
1、header(关键)
记录主要的修改类型和内容
由三个部分组合:type(必填)、scope(可选)、subject(必填)
1.1、type
必填,message的类型,有以下几种常用的类型
- feat:提交新的功能,记忆:feature
- fix:解决了bug
- docs:修改的是文档相关的内容,记忆:documentation
- style:格式修改,没有修改代码逻辑,比如格式化、换行等
- refactor:重构代码,既没有新增功能,也没有修复bug,比如提取某段代码为一个方法、重构某个功能
- perf:性能、体验优化等,记忆:performance性能
- test:新增test用例或修改现有测试用例
- chore:构建过程或辅助工具的变动,非src和test的修改,比如构建流程, 依赖管理等
当同时有feat、fix和其他类型时,类型取feat、fix。
1.2、scope
非必填,用于说明此次提交影响的范围,比如数据层、控制层、视图层等
1.3、subject
必填,此次提交的简短描述
- 动词开头,第一人称现在时,比如add,而不用added、adds
- 第一个字母小写
- 句尾不加句号(.)
2、body(可省略)
详细的描述,可多行,与header之间空一行
3、footer(可省略)
footer只用于以下两种情况
- 不兼容变动
以BREAKING CHANGE开头,后面是变动的描述、变动的理由以及迁移的方法
什么叫不兼容变动,比如用户密码的加密方式发生改变
- 关闭issue
当前提交修改了某个issue
整体的git message如下
feature(数据层): 简短描述
详细描述
BREAKING CHANGE: 不兼容变动
Closes 关闭issue
如用IDEA, 可以使用Git Commit Message Helper插件