Git commit校验工具commitlint的配置与使用

news2025/8/12 15:49:56

前端环境要求

node: 16.x
npm: 8.x

Tip:npm版本须大于等于 7.24.2,过低的话可能会导致下面有的命令无法使用,需要手动在 package.json 中自行设置。

工具

husky

操作 git 钩子的工具

commitlint

commit 信息校验工具

commitizen

commit自动化提示工具,简称cz

cz-customizable

可自定义的cz适配器

commitlint-config-git-commit-emoji

emoji插件

安装

安装husky工具

安装 husky插件

npm i husky -D

在package.json中添加脚本

npm set-script prepare "husky install" 

根目录创建.husky文件夹,将 git hooks 钩子交由husky执行

npm run prepare 

添加 commit-msg 钩子,执行信息校验

npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'

安装commitlint

安装 commit 校验工具

npm i commitlint @commitlint/config-conventional -D
  • @commitlint/config-conventional 这是一个规范配置,标识采用什么规范来执行消息校验, 这个默认是Angular的提交规范

创建 commitlint.config.js 配置文件

echo "module.exports = {extends: ['@commitlint/config-conventional']}" > commitlint.config.js

安装commitizen

安装自动化提示工具

npm i commitizen cz-conventional-changelog -D

package.json 中添加 commit 指令, 执行 git-cz 指令

npm set-script commit "git-cz" 

初始化命令行的选项信息

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

就可以在命令行中选择需要提交的git commit type了。
在这里插入图片描述

安装可自定义的cz适配器

因为commitizen只支持英文,如果我想要支持中文指令和emoji,那么就必须安装可自定义的cz适配器了

安装cz适配器

npm i -D commitlint-config-cz  cz-customizable

在根目录创建 .cz-config.js

module.exports = {
  types: [
    {
      value: ':sparkles: feat',
      name: '✨ feat:     新功能'
    },
    {
      value: ':bug: fix',
      name: '🐛 fix:      修复bug'
    },
    {
      value: ':package: build',
      name: '📦️ build:    打包'
    },
    {
      value: ':zap: perf',
      name: '⚡️ perf:     性能优化'
    },
    {
      value: ':tada: release',
      name: '🎉 release:  发布正式版'
    },
    {
      value: ':lipstick: style',
      name: '💄 style:    代码的样式美化'
    },
    {
      value: ':recycle: refactor',
      name: '♻️  refactor: 重构'
    },
    {
      value: ':pencil2: docs',
      name: '✏️  docs:     文档变更'
    },
    {
      value: ':white_check_mark: test',
      name: '✅ test:     测试'
    },
    {
      value: ':rewind: revert',
      name: '⏪️ revert:   回退'
    },
    {
      value: ':rocket: chore',
      name: '🚀 chore:    构建/工程依赖/工具'
    },
    {
      value: ':construction_worker: ci',
      name: '👷 ci:       CI related changes'
    }
  ],
  messages: {
    type: '请选择提交类型(必填)',
    customScope: '请输入文件修改范围(可选)',
    subject: '请简要描述提交(必填)',
    body: '请输入详细描述(可选)',
    breaking: '列出任何BREAKING CHANGES(可选)',
    footer: '请输入要关闭的issue(可选)',
    confirmCommit: '确定提交此说明吗?'
  },
  allowCustomScopes: true,
  // 跳过问题
  skipQuestions: ['body', 'footer'],
  subjectLimit: 72
}

将新脚本添加到您的 package.json

"scripts" : {
  ...
  "commit": "git add . && cz-customizable"
}

安装git-commit-emoji

安装emoji插件

npm i -D  commitlint-config-git-commit-emoji 

更新 commitlint.config.js

移除extends中原来的 @commitlint/config-conventional,加入'git-commit-emoji', 'cz'

module.exports = {
  extends: ['git-commit-emoji', 'cz']
}

含emoji的自动化提示选项列表

使用 npm run commit 代替 git commit
在命令行中输入 npm run commit ,即可通过键盘上下键选择需要要的commit type了。
含emoji的自动化提示选项列表

其他

1. 使用自动化工具后,还可以用 git commit - m ""提交代码吗?

可以。
配置自动化工具后,不仅支持npm run commit自动化提示选择提交,也可以继续使用 git commit - m ""提交,只是写type的时候前面还需要加上emoji的字符串。

示例:git commit -m ":sparkles: feat: 新增登录功能"

在这里插入图片描述
查看git日志记录,显示已经提交成功。

在这里插入图片描述

2. husky报错导致提交失败?

删除根目录下.husky文件夹,在命令行重新运行 npm run prepare npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/15084.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]java毕业设计农贸产品交易系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

【freeRTOS】操作系统之六-低功耗模式

六,低功耗模式 本章节为大家讲解 FreeRTOS 本身支持的低功耗模式 tickless 实现方法,tickless 低功耗机制是当前小型 RTOS 所采用的通用低功耗方法,比如 embOS,RTX 和 uCOS-III(类似方法)都有这种机制。ti…

深度学习 Day 19——数据增强

深度学习 Day 19——数据增强 文章目录深度学习 Day 19——数据增强一、前言二、我的环境三、前期工作1、导入依赖项并设置GPU2、加载数据3、配置数据集并进行归一化处理4、可视化数据四、数据增强五、数据增强方式1、将其签入model中2、在Dataset数据集中进行数据增强六、编译…

【金融】经济崛起之中的东南亚

由于全球范围内的重大危机事件,经济贸易摩擦加剧,地区局势动荡不安,全世界主要经济体的经济发展都受到了极大的冲击,但东南亚地区却在这一全球衰退的背景之下给出了即为亮眼的经济表现。东盟国家近年来保持着较高的经济增速&#…

792. 匹配子序列的单词数 : 常规预处理优化匹配过程

题目描述 这是 LeetCode 上的 792. 匹配子序列的单词数 ,难度为 中等。 Tag : 「二分」、「哈希表」 给定字符串 s 和字符串数组 words, 返回 words[i] 中是 s 的子序列的单词个数 。 字符串的 子序列 是从原始字符串中生成的新字符串,可以从中删去…

初学者设计PCB,如何检查光绘文件的断头线

设计一款完整的PCB线路板,需要经过很多个繁琐而且复杂的工序。一般主要包括明确产品需求、硬件系统设计、器件选型、PCB绘制、PCB生产打样、焊接调试等步骤。 一般设计师都会有自己积累的设计质量检查清单,其中的条目部分来源于公司或部门的规范、另一部…

Linux开发工具VI/VIM

Linux开发工具VI/VIM 文章目录Linux开发工具VI/VIM一、Linux 软件包管理器 yum语法安装和卸载sl(小火车跑动)软件包二、编辑器VI/VIM1.基本介绍2.基础使用接下来介绍vim使用正常模式命令集末行模式命令集三、VIM优化总结一、Linux 软件包管理器 yum yum…

大学生个人网页模板 简单网页制作作业成品 极简风格个人介绍HTML网页设计(舞蹈培训网页)

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材,DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 校园篮球网页设计 | 足球体育运动 | 体育游泳运动 | 兵乓球 | 网球 | 等网站的设计与制作 | HTML期末大学生网页设计作业,Web大学生网页 H…

大学生《Web课程谁》期末网页制作 HTML+CSS+JavaScript 网页设计实例 瑜伽网站企业网站制作

🎉精彩专栏推荐 💭文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业: 【📚毕设项目精品实战案例 (10…

单商户商城系统功能拆解32—营销中心—消费奖励

单商户商城系统,也称为B2C自营电商模式单店商城系统。可以快速帮助个人、机构和企业搭建自己的私域交易线上商城。 单商户商城系统完美契合私域流量变现闭环交易使用。通常拥有丰富的营销玩法,例如拼团,秒杀,砍价,包邮…

Word论文排版教程

设置样式 要求: 以下以修改“大标题”为例,其他以此类推 1、大标题 再点击右下角的“段落” 2、标题4… 我们发现word默认只显示了三级标题的样式,如果我们还要更多的样式: (选择“所有样式”即可) …

智能微型断路器应该怎么选型?

安科瑞 华楠 智能微型断路器应用于户内建筑物及类似场 所的工业、商业、民用建筑及基础设施等领域低压终端配电网络。 选型分类——智能微型断路器 类型 型号 功能 智能小型断路器 ASCB1-63-C16/32/63-1P 可实时监测单相电压、电流、功率、电能和温度等参量;…

Android aar 打包事项

我们在开发中难免会遇到把现有的module变成库文件SDK的情况,aar包中不仅可以包含代码,也可以包含资源文件,是一种常用的库文件方式。打包的事项主要有以下几点: 在root project工程下的build.gradle文件中引入"com.kezong:f…

自动驾驶入门:规划

目录 概念 基本原理 将地图转化为数据结构图 路径查找算法 A* A*在现实中的应用 地图级轨迹生成 Frenet 坐标系 速度- 路径解耦规划 路径生成与选择 ST图 速度规划 优化 路径-速度规划的轨迹生成 Lattice规划 ST轨迹的终止状态 SL轨迹的终止状态 Lattice规划的…

JVM——虚拟机类加载机制

类加载时机 加载loading 加载.class文件的方法 类连接阶段 验证阶段 准备阶段 解析阶段 初始化 简而言之,为类的静态变量赋予正确的初始值。如果前面的步骤都没有问题,那么表示类可以顺利装载到系统中,此时才会开始执行Java字节码。即&…

微信小程序 python电影票务系统-nodejs电影票预订系统

目 录 1绪论 1 1.1项目研究的背景 1 1.2开发意义 1 1.3项目研究现状及内容 5 1.4论文结构 5 2开发技术介绍 7 2.1 B/S架构 7 2.2 MySQL 介绍 7 2.3 MySQL环境配置 7 2.4 Java语言简介 8 2.5微信小程序技术 8 3系统分析 9 3.1可行性分析 9 3.1.1技术可行性 9 3.1.2经济可行性 9 …

沉睡者IT - 听我给你科普什么是WEB3.0?

推荐关注新博主,点击上面关注吧 ↑↑ 不出意外的话,今年下半年最火的概念大概率是web三点零了。 如果说去年元宇宙霸占了科技和金融圈的榜一的话,今年的榜一估计会变成web三点零。 什么是web三点零? 真的没有那么玄乎啊&#xf…

木马特征值免杀

文章目录木马特征值免杀一. 木马特征值免杀0x01. 灰鸽子配置生成木马0x02. 使用MyCCL复合特征码定位器反复缩小目标进行定位0x03. 直到定位到很小的区间0x04. 用工具将文件偏移地址0009B9C3转换成内存地址0049C5C30x05. 使用OD跳转特征值语句的执行顺序以实现免杀0x06. 将修改后…

微信录屏怎么录?微信聊天记录怎么录制下来

微信作为我们日常使用的沟通工具,里面保留着许多的信息。在有些时候,我们可能会遇到需要用录屏功能,将微信里的信息分享出去的场景。可是微信自身是不带录屏功能的,微信录屏怎么录?我们究竟要怎么将信息给录制下来呢&a…

万字博客带你了解Spring Framework 的全貌

1.写在前面 我之前出过一个系列介绍的是spring的源码的系列,但是由于当时个人的水平有限,有些地方介绍的也是模棱两可的,打算重启这块内容,上次只是介绍其中的一部分,例如国际化,事件等等这块的源码都没有…