git检查提交分支和package.json的version版本是否一致

这里写自定义目录标题

以下是基于 Git Hooks 的完整解决方案,通过 husky 和自定义脚本实现分支名与版本号一致性校验:

一、核心实现步骤‌

1.安装必要依赖‌

clike 复制代码
npm install [email protected] [email protected] --save-dev

husky:管理 Git 钩子

lint-staged:针对暂存区文件执行检查

2.初始化 Husky‌

clike 复制代码
npx husky-init && pnpm install

生成 .husky 目录及 pre-commit 钩子文件

3.创建校验脚本‌

在项目根目录新建 scripts/check-version.js:

clike 复制代码
import fs from "fs"
import { execSync } from "child_process"

// 获取packageJson内容
const packageJson = JSON.parse(fs.readFileSync("package.json", "utf8"))

// 获取当前分支名
const branchName = execSync("git rev-parse --abbrev-ref HEAD").toString().trim()

if (!branchName.includes(packageJson.version)) {
  console.error(`版本 ${packageJson.version} 与分支名称 ${branchName} 不一致,不允许提交`)
  process.exit(1)
}

4.配置 lint-staged‌

修改 package.json:

clike 复制代码
{
  "lint-staged": {
    "*.{js,jsx,ts,tsx}": [
      "prettier --write"
    ],
    "*.vue": [
      "prettier --write"
    ]
  }
  "scripts": {
    "prettier": "npx prettier . --write",
    "prepare": "husky install"
  }
}

5.更新 Husky 钩子‌

修改 .husky/pre-commit:

clike 复制代码
npx lint-staged
node scripts/check-version.js

二、校验规则定制(按需调整)‌

clike 复制代码
// 示例1: 严格匹配分支名与版本号
if (branch !== `release/v${version}`) { /*...*/ }

// 示例2: 允许分支名包含版本号前缀
const versionPrefix = version.split('.').slice(0, 2).join('.');
if (!branch.startsWith(`feat/${versionPrefix}`)) { /*...*/ }

三、工作流程说明‌

步骤 触发条件 执行内容 结果处理

  • 提交代码‌ git commit 触发 pre-commit 钩子 → 执行版本校验脚本
  • pre-commit 钩子脚本:
    -- npx lint-staged执行package.json的lint-staged的配置
    -- node scripts/check-version.js执行检查的脚本
    --- 校验通过‌ 分支名与版本号匹配 正常提交 流程继续
    --- 校验失败‌ 名称不一致 输出错误信息并终止提交 返回非零状态码阻止提交

四、注意事项‌

分支命名规范‌

  • 建议采用 语义化版本+分支类型 格式(如 feat/1.2.0 或 release/1.2.0)

版本号管理‌

  • 使用 npm version 命令自动更新版本号:
javascript 复制代码
npm version patch -m "升级版本至 %s"

多环境适配‌

  • 若需豁免特定分支(如 main),可在脚本中添加白名单:
javascript 复制代码
const whitelist = ['main', 'master'];
if (whitelist.includes(branch)) return;
  • 该方案通过 Git 提交前强制校验,确保分支与版本号的关联性,适用于需要严格版本控制的敏捷开发场景。
相关推荐
朴拙数科6 小时前
Json rpc 2.0比起传统Json在通信中的优势
网络协议·rpc·json
仍然探索未知中9 小时前
Git分支管理
git
小妖66610 小时前
windows11 安装好后右键没有 git bash 命令
git
只做开心事10 小时前
Git 多人协作
git
freejackman10 小时前
Git从入门到精通
git·gitee·gitlab·github
兔子坨坨13 小时前
pycharm连接github(详细步骤)
windows·git·学习·pycharm·github
大大小小聪明20 小时前
Git合并多个提交方法详解
git·github
LYPHARD MELODY。1 天前
将 JSON 批量转换为 XML:深度解析与完整实现指南
xml·json
爱吃涮毛肚的肥肥(暂时吃不了版)1 天前
项目班——0510——JSON网络封装
c++·算法·json
GISer_Jing1 天前
[前端高频]数组转树、数组扁平化、深拷贝、JSON.stringify&JSON.parse等手撕
前端·javascript·json