✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 介绍
  • commitlint
  • 安装
  • 配置
  • husky
  • 安装
  • 配置
  • 使用
  • 常用husky钩子
  • 自定义husky init脚本
  • 注意
  • 参考

Was this helpful?

  1. Docs
  2. Articles
  3. Standards

使用husky+commitlint规范代码提交

Previouscommit规范Next使用semantic-release自动管理版本号

Last updated 10 months ago

Was this helpful?

介绍

在项目迭代中,我们希望在代码提交时,能够规范提交信息,防止提交信息不规范,导致代码提交时,出现错误。这时候,我们可以使用 husky + commitlint 来实现。

commitlint

安装

# npm
npm i -D commitlint @commitlint/config-conventional @commitlint/cli

# yarn
yarn add -D commitlint @commitlint/config-conventional @commitlint/cli

配置

::: code-group

module.exports = {
  extends: ['@commitlint/config-conventional'],
  rules: {
    // 'body-leading-blank': [2, 'always'], // 主体前有空行,默认就是 always
    // 'footer-leading-blank': [2, 'always'], // 末行前有空行,默认就是 always
    // 'header-max-length': [2, 'always', 108], // 首行最大长度,默认就是 always,72
    // 'subject-empty': [2, 'never'], // 标题不可为空,默认就是 never
    // 'type-empty': [2, 'never'], // 类型不可为空,默认就是 never

    // 允许的类型
    'type-enum': [
      2,
      'always',
      [
        'build', // 构造工具、外部依赖(webpack、npm)
        'chore', // 不涉及 src、test 的其他修改(构建过程或辅助工具的变更)
        'ci', // 修改项目继续集成流程(Travis,Jenkins,GitLab CI,Circle等)
        'docs', // 文档
        'feat', // 新增功能
        'fix', // bug 修复
        'perf', // 性能优化
        'refactor', // 重构
        'revert', // 回退
        'style', // 代码风格(不影响代码含义)
        'test', // 测试

        // 下面几个是自定义新增的
        'wip', // 开发中
        'refine', // 小优化,没有到 refactor 的程度
      ]
    ]
  }
}

:::

husky

安装

# npm
npm i -D husky

# yarn
yarn add -D husky

配置

::: code-group

{
  "scripts": {
    "prepare": "husky && npm run huskyInit",
    "huskyInit": "zx ./huskyInit.mjs"
  }
}
{
  "scripts": {
    "prepare": "husky install && npm run huskyInit",
    "huskyInit": "zx ./huskyInit.mjs"
  }
}

:::

使用

正常 npm i 或者 yarn install 后,会自动执行 prepare 脚本,然后会自动安装 husky 的钩子。

常用husky钩子

  1. pre-commit:在提交之前执行,用于检查代码是否规范,如果不规范,则不允许提交。

  2. commit-msg:在提交之前执行,用于检查提交信息是否规范,如果不规范,则不允许提交。

  3. pre-push:在推送之前执行,用于检查代码是否规范,如果不规范,则不允许推送。

  4. post-commit:在提交之后执行,用于记录提交信息。

  5. post-merge:在合并之后执行,用于记录合并信息。

  6. post-checkout:在检出之后执行,用于记录检出信息。

  7. post-receive:在接收之后执行,用于记录接收信息。

  8. post-rewrite:在重写之后执行,用于记录重写信息。

  9. post-update:在更新之后执行,用于记录更新信息。

  10. pre-rebase:在重写之前执行,用于检查代码是否规范,如果不规范,则不允许重写。

  11. pre-receive:在接收之前执行,用于检查代码是否规范,如果不规范,则不允许接收。

  12. pre-auto-merge:在自动合并之前执行,用于检查代码是否规范,如果不规范,则不允许自动合并。

  13. pre-auto-gc:在自动垃圾回收之前执行,用于检查代码是否规范,如果不规范,则不允许自动垃圾回收。

::: code-group

#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
# 加入path
PATH=$PATH:/usr/local/bin:/usr/local/sbin
npx --no-install -- lint-staged
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
# 加入path
PATH=$PATH:/usr/local/bin:/usr/local/sbin
npx --no-install commitlint --edit 

:::

自定义husky init脚本

可以使用 bash , node , zx 达到目的 三选一即可,zx 和 node 语法一样的,主要是 import 改成 require

::: code-group

# bash脚本执行husky-init
# commit-msg
echo '#!/usr/bin/env sh' > .husky/_/commit-msg
echo '. "$(dirname -- "$0")/husky.sh"' >> .husky/_/commit-msg
echo 'npx --no-install commitlint --edit' >> .husky/_/commit-msg

# pre-commit
echo '#!/usr/bin/env sh' > .husky/_/pre-commit
echo '. "$(dirname -- "$0")/husky.sh"' >> .husky/_/pre-commit
echo '# npx --no-install -- lint-staged' >> .husky/_/pre-commit
#!/usr/bin/env zx
/**
 * @Description: zx脚本执行husky-init
 * @Author: MuYi086
 * @Email: 1258947325@qq.com
 * @Blog: https://github.com/MuYi086/blog
 * @Date: 2024/05/06 15:23
 */
import fs from 'fs/promises'
import chalk from 'chalk'
const dir = '.husky/_/'
const preCommitFile = 'pre-commit'
const commitMsgFile = 'commit-msg'
/**
 * 往固定路径的文件同步写入内容
 * @param {*} path
 * @param {*} content
 */
async function writeCommitScriptToHusky (path, content) {
  try {
    await fs.writeFile(path, content)
  } catch (err) {
    console.log(err)
  }
}

/**
 * 往固定路径的文件同步追加内容
 * @param {*} path
 * @param {*} content
 */
async function addCommitScriptToHusky (path, content) {
  try {
    await fs.appendFile(path, content)
  } catch (err) {
    console.log(err)
  }
}

/**
 * 启动
 */
async function start () {
  const commitMsgPath = `${dir}${commitMsgFile}`
  const preCommitPath = `${dir}${preCommitFile}`
  console.log(chalk.blue('准备执行husky-init'))
  // commit-msg
  console.log(chalk.blue('初始化husky commit-msg'))
  await writeCommitScriptToHusky(commitMsgPath, '#!/usr/bin/env sh')
  await addCommitScriptToHusky(commitMsgPath, '\r\n. "$(dirname -- "$0")/husky.sh"')
  await addCommitScriptToHusky(commitMsgPath, '\r\nnpx --no-install commitlint --edit')
  // pre-commit
  console.log(chalk.blue('初始化husky pre-commit'))
  await writeCommitScriptToHusky(preCommitPath, '#!/usr/bin/env sh')
  await addCommitScriptToHusky(preCommitPath, '\r\n. "$(dirname -- "$0")/husky.sh"')
  await addCommitScriptToHusky(preCommitPath, '\r\n# npx --no-install -- lint-staged')
  console.log(chalk.green('已完成husky init'))
}
start()

:::

注意

::: warning husky8 生成 hook 目录与 9 不一致, ::: code-group

const dir = '.husky/'
const dir = '.husky/_/'

:::

参考

commit规范说明
commitlint 规范
husky