前端优化之路:git commit 校验拦截

【前言】

前面在git分支规范那篇文章里,介绍了commit提交规范,如下图

但是想要做到高效落地执行,就需要做些别的功课,先展示下成果图

没错,对不符合规范的commit进行了拦截,符合才可以成功提交。

【前期准备】

需要了解git hooks,它是git的钩子,就像vue拥有自己的钩子一样

官方文档:https://git-scm.com/docs/githooks

本次优化中,只需要使用 commit-msg 钩子,它不仅可以实现 commit拦截,还能实现merge拦截

项目安装 husky,建议稳定版本4.3.8

npm install husky@4.3.8

【项目配置】

在项目package.json中,与scripts同级层配置钩子,npm run xxx,xxx为自定义的脚本执行命令

在scripts中配置脚本命令。xxx 为自定义的脚本名,会使node打开并执行指定目录下的js脚本文件,所以node后跟着的是自定义的脚本存放地址

【自定义脚本】

在上述脚本执行路径创建commit-msg.js,文件名自定义,对应上面的路径就行。

先引入fs工具包,不用安装,它是node的工具包。

自定义提交类型(type)

为了提示信息能够醒目,自定义颜色(如果无需醒目,这步可省略)

自定义基本提示语

获取commit相关对象

对三种情况进行校验,提示并拦截

另外,还可配置merge的拦截

到这里,就配置完成了,达到了预期效果

相关推荐
学嵌入式的小杨同学26 分钟前
【Linux 实战】Makefile 自动化构建进阶:静态库 / 动态库通用模板(一键编译 + 系统安装)
linux·开发语言·git·vscode·spring·vim·ux
小白菜学前端2 小时前
Git 推送 Vue 项目到远程仓库完整流程
前端·git
小wanga3 小时前
【Git】git reset 详解
git
CoderJia程序员甲3 小时前
GitHub 热榜项目 - 日榜(2026-01-29)
git·ai·开源·llm·github
小码吃趴菜4 小时前
git工具简介
git
小邓的技术笔记4 小时前
Git Push 失败:分支名大小写不一致问题解析
git
艺杯羹4 小时前
Git入门基础:从概念到安装的完整指南
git·elasticsearch·开发工具·版本控制·git入门·代码托管
不断学习加努力4 小时前
git代码管理的一些基础知识
git
Java后端的Ai之路6 小时前
【Git版本控制】-趣味解说Git核心知识
大数据·git·elasticsearch
是店小二呀6 小时前
Git 分支核心指南:原理、合并策略与实战技巧
git