Git Commit 规范

简介: 今天来补充完 Commit Message 提交说明规范。

前言


前面的介绍,利用了 husky 与 lint-staged 使得在提交之前做一些 ESLint 和 Prettier 的操作,今天来补充完 Commit Message 提交说明规范。


Git 是目前最先进的分布式版本控制系统,Git 每次提交代码时,都需要写 Commit Message(提交说明),否则不允许提交。

# 单行(亦可多行输入,输入一个双引号,按 Enter 键即可,最后补全一个双引号)
$ git commit -m "xxx"
# 多行输入,输入命令进入编辑模式
$ git commit


在团队多人协作中,一份清晰简明的 Commit Message 很重要,它可以让我们清楚了解本次代码提交的目的以及解决了具体什么问题。也可能让后续 Code Review、信息查找、版本回退都更加高效可靠。


目前,社区有多种 Commit Message 的写法规范。本文介绍 Angular 规范,这是目前使用最广的写法,比较合理和系统化,并且有配套的工具。


正文


Commit Message 规范


每次提交,Header 是必需的,而 Body 和 Footer 可以省略。

不管哪一部分,任何一行都不得超过 72 个字符(或 100 个字符)。这是为了避免自动换行影响美观。

<Header>
<空行>
<Body>
<空行>
<Footer>


Header 部分


它包括 typescopesubject 三部分,其中 typesubject 是必须的,而 scope 是可选的。

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


  1. type 用于说明 commit 的类型,只允许使用下面几个标识:


  • feat 新功能
    A new feature
  • fix 修复 bug
    A bug fix
  • docs 仅包含文档的修改
    Documentation only changes
  • style  格式化变动,不影响代码逻辑。比如删除多余的空白,删除分号等
    Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
  • refactor 重构,既不是新增功能,也不是修改 bug 的代码变动
    A code change that neither fixes a bug nor adds a feature
  • perf 性能优化
    A code change that improves performance
  • test 增加测试
    Adding missing tests or correcting existing tests
  • build 构建工具或外部依赖包的修改,比如更新依赖包的版本等
    Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)
  • ci 持续集成的配置文件或脚本的修改
    Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)
  • chore 杂项,其他不修改源代码与测试代码的修改
    Other changes that don't modify src or test files
  • revert 撤销某次提交
    Reverts a previous commit


如果 typefeatfix,则该 commit 将肯定会出现在 Change Log 中。其他情况(docschorestylerefactortest)由你决定,要不要放入 Change Log 中,建议是不要。


  1. scope 用于说明 commit 影响的范围,比如数据层、控制层、视图层等。根据项目本身情况处理,如: views, components, utils, test...
  2. subject 是 commit 目的的简短描述,不超过 50 个字符。


  • 以动词开头,使用第一个人称现在时,比如 change,而不是 changed 或者 changes
  • 第一字母小写
  • 结尾不加句号(.


Body 部分


Body 部分是对本次 commit 的详细描述,可以分成多行。下面是一个范例:

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


注意两点:

  • 使用第一人称现在时,比如使用 change 而不是 changed 或者 changes。
  • 应该说明代码变动的动机,以及与之前行为的对比。


Footer 部分


Footer 部分只用于两种情况。

  1. 不兼容的变动


如果当前代码与上一个版本不兼容,则 Footer 部分以 BREAKING CHANGE 开头,后面是对变动的描述以及变动理由和迁移方法。

BREAKING CHANGE: isolate scope bindings definition has changed.
    To migrate the code follow the example below:
    Before:
    scope: {
      myAttr: 'attribute',
    }
    After:
    scope: {
      myAttr: '@',
    }
    The removed `inject` wasn't generaly useful for directives so there should be no code using it.


  1. 关闭 Issue

如果当前 commit 针对某个 issue,那么旧可以在 Footer 部分关闭这个 issue。


# 关闭单个
Closes #123
# 关闭多个
Closes #123, #234, #345


Revert


还有一种特殊情况,如果当前 commit 用于撤销以前的 commit,则必须以 revert: 开头,后面跟着被撤销 Commit 的 Header。

Body 部分格式是固定的,必须写成 This reverts commit <hash>.,其中的 hash 是被撤销 commit 的 SHA 标识符。

revert: feat(pencil): add 'graphiteWidth' option
This reverts commit 667ecc1654a317a13331b17617d973392f415f02.

如果当前 commit 与被撤销的 commit 在同一个发布(release)里面,那么它都不会出现在 Change Log 里面。如果两者在不同的发布,那么当前 commit,会出现在 Change Log 的 Reverts 小标题下面。


Commitizen


Commitizen 是一个撰写符合上面 Commit Message 标准的一款工具。

可以全局安装或者项目本地安装,我采用后者,但都会介绍一下。


全局安装

# 全局安装方法
# 下载
$ yarn global add commitizen cz-conventional-changelog
# 创建 .czrc 文件
$ vi ~/.czrc
# 写入如下内容并保存
{ "path": "cz-conventional-changelog" }
# 完了之后,可以使用 git cz 来代替 git commit 了。


项目局部安装

$ yarn add --dev commitizen cz-conventional-changelog


接着往 package.json 添加配置:

{
  "scripts": {
    "commit": "git-cz",
    "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md"
  },
  "config": {
    "commitizen": {
      "path": "./node_modules/cz-conventional-changelog"
    }
  }
}


commitizen 与 cz-conventional-changelog 的关系?

commitizen 根据不同的 Adapter 配置 Commit Message。比如,要使用 Angular 的 Commit Message 格式,可以安装 cz-conventional-changelog。还有很多其他的 Adapter...


实践


其中 scope、breaking changes、issue 等非必需项可回车跳过。


3.webp.jpg


生成 Change Log


如果你的所有 Commit 都符合 Angular 格式,那么发布新版本时, Change Log 就可以用脚本自动生成。


生成的文档包括以下三个部分。


  • New features
  • Bug fixes
  • Breaking changes.


conventional-changelog 就是生成 Change Log 的工具,此前已安装并配置

{
  "scripts": {
    "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md"
  }
}


运行以下命令生成 CHANGELOG 文件,其中 featfix 类型的变动会生成在里面。

$ yarn run changelog


每个部分都会罗列相关的 commit ,并且有指向这些 commit 的链接。当然,生成的文档允许手动修改,所以发布前,你还可以添加其他内容。

文章的示例 Demo 在这里  GitHub: wechat_applet_demo,欢迎 Star 。


参考


目录
相关文章
|
3月前
|
开发工具 git
使用Git下载指定版本或指定commit
使用Git下载指定版本或指定commit
|
4月前
|
存储 人工智能 缓存
Git Commit规范:为什么有些公司要求变更行数限制?·优雅草卓伊凡
Git Commit规范:为什么有些公司要求变更行数限制?·优雅草卓伊凡
203 3
Git Commit规范:为什么有些公司要求变更行数限制?·优雅草卓伊凡
|
7月前
|
人工智能 前端开发 Java
用git rebase命令合并开发阶段中多条commit提交记录
通过 `git rebase`,可以合并多个提交记录,使开发历史更简洁清晰。操作分为 6 步:查看提交历史 (`git log --oneline`)、设置需合并的提交数 (`git rebase -i HEAD~N`)、修改动作标识为 `s`(squash)、保存退出编辑、调整提交信息、强制推送至远程仓库 (`git push -f`)。此方法适合清理本地无关提交,但若有团队协作或冲突风险,需谨慎使用以避免问题。
1071 60
|
5月前
|
JavaScript 前端开发 持续交付
实际工作中 Git Commit 代码提交规范是什么样的?
实际工作中 Git Commit 代码提交规范是什么样的?
297 7
|
6月前
|
前端开发 开发工具 git
Git报错处理:解决git commit时的lint-staged错误提示。
极好的,你对Git的lint-staged出了一个令人头疼的问题。让我们一起钻研一下,找到一种方法来解决一切。 首先,我们要确定你是在做什么操作时候遇到了问题。lint-staged通常在我们运行 git commit 时启动,它做的工作是在你提交之前运行一些指定的命令检查你的代码。当lint-staged报错,多半是因为检查未通过,或者它试图运行的命令存在问题。 让我们以一种图解的方式来描绘一下这个过程,就像canvas上的画面那样。git正在温柔的将你的修改捆绑起来,准备提交。突然,lint-staged走了出来,并开始盘问着Git,寻找可能的错误。如果lint-staged找到了什么
741 24
|
开发工具 git
GIT:如何合并已commit的信息并进行push操作
通过上述步骤,您可以有效地合并已提交的信息,并保持项目的提交历史整洁。记得在执行这些操作之前备份当前工作状态,以防万一。这样的做法不仅有助于项目维护,也能提升团队协作的效率。
684 5
|
开发工具 git
GIT:如何合并已commit的信息并进行push操作
通过上述步骤,您可以有效地合并已提交的信息,并保持项目的提交历史整洁。记得在执行这些操作之前备份当前工作状态,以防万一。这样的做法不仅有助于项目维护,也能提升团队协作的效率。
574 3
|
消息中间件 小程序 Java
【规范】看看人家Git提交描述,那叫一个规矩
本文通过IDEA中的Git描述规范插件【git commit message helper】,介绍了Git提交描述的规范流程,强调了团队开发中统一标准的重要性,并通过实例展示了规范的提交记录如何提高代码管理和维护效率。最后,文章提供了几个实用的Git提交描述案例,帮助读者更好地理解和应用这些规范。
3155 0
【规范】看看人家Git提交描述,那叫一个规矩
|
敏捷开发 小程序 持续交付
【规范】Git分支管理,看看我司是咋整的
本文介绍了Git分支管理规范的重要性及其在企业中的应用。通过规范化的分支管理,可加速团队协作、确保代码质量、维护主分支稳定,并支持敏捷开发。文中详细描述了主分支(如master、develop)和辅助分支(如feature、hotfix)的作用,并提供了实际开发流程示例,包括开发前、开发中、提测、预生产和部署上线等阶段的操作方法。旨在帮助团队提高效率和代码质量。
3179 0
【规范】Git分支管理,看看我司是咋整的
|
开发工具 git
Git——commit的提交规范
Git——commit的提交规范
266 4