当前位置: 首页 > news >正文

如何实现pnpm commit拦截

首先需要在package.json中下载这几个包

执行命令参照http://typicode.github.io/husky/get-started.html

npx husky init

就会在项目的根目录出现这几个文件

// pre-commit
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"echo 'husky: pre-commit'
pnpm lint && pnpm spellcheck
//commit-msg
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"echo 'husky: commit'
# 用来检测commmit msg是否符合规范,意思是用commitlint来执行校验,就是通过commitlint.config.cjs的细则来进行校验
npx commitlint --edit $1

然后在package.json中添加config

之后在项目根目录新建文件

这里的内容是摘抄https://cz-git.qbb.sh/zh/config/

如上的图片中使用的js,但是因为兼容原因使用cjs


module.exports = {// 添加规则配置extends: ['@commitlint/config-conventional'],rules: {// @see: https://commitlint.js.org/#/reference-rules},prompt: {alias: { fd: 'docs: fix typos' },messages: {type: '选择你要提交的类型 :',scope: '选择一个提交范围(可选):',customScope: '请输入自定义的提交范围 :',subject: '填写简短精炼的变更描述 :\n',body: '填写更加详细的变更描述(可选)。使用 "|" 换行 :\n',breaking: '列举非兼容性重大的变更(可选)。使用 "|" 换行 :\n',footerPrefixesSelect: '选择关联issue前缀(可选):',customFooterPrefix: '输入自定义issue前缀 :',footer: '列举关联issue (可选) 例如: #31, #I3244 :\n',confirmCommit: '是否提交或修改commit ?'},types: [{ value: 'feat', name: 'feat:     新增功能 | A new feature' },{ value: 'fix', name: 'fix:      修复缺陷 | A bug fix' },{ value: 'docs', name: 'docs:     文档更新 | Documentation only changes' },{ value: 'style', name: 'style:    代码格式 | Changes that do not affect the meaning of the code' },{ value: 'refactor', name: 'refactor: 代码重构 | A code change that neither fixes a bug nor adds a feature' },{ value: 'perf', name: 'perf:     性能提升 | A code change that improves performance' },{ value: 'test', name: 'test:     测试相关 | Adding missing tests or correcting existing tests' },{ value: 'build', name: 'build:    构建相关 | Changes that affect the build system or external dependencies' },{ value: 'ci', name: 'ci:       持续集成 | Changes to our CI configuration files and scripts' },{ value: 'revert', name: 'revert:   回退代码 | Revert to a commit' },{ value: 'chore', name: 'chore:    其他修改 | Other changes that do not modify src or test files' }],useEmoji: false,emojiAlign: 'center',useAI: false,aiNumber: 1,themeColorCode: '',scopes: [],allowCustomScopes: true,allowEmptyScopes: true,customScopesAlign: 'bottom',customScopesAlias: 'custom',emptyScopesAlias: 'empty',upperCaseSubject: null,markBreakingChangeMode: false,allowBreakingChanges: ['feat', 'fix'],breaklineNumber: 100,breaklineChar: '|',skipQuestions: [],issuePrefixes: [// 如果使用 gitee 作为开发管理{ value: 'link', name: 'link:     链接 ISSUES 进行中' },{ value: 'closed', name: 'closed:   标记 ISSUES 已完成' }],customIssuePrefixAlign: 'top',emptyIssuePrefixAlias: 'skip',customIssuePrefixAlias: 'custom',allowCustomIssuePrefix: true,allowEmptyIssuePrefix: true,confirmColorize: true,scopeOverrides: undefined,defaultBody: '',defaultIssues: '',defaultScope: '',defaultSubject: ''}
}

然后配合package.json这里的脚本使用,这里的脚本内容是

配合下载commit相关的包

  "devDependencies": {"eslint": "9.1.0","@eslint/js": "9.1.0","typescript": "5.5.2","typescript-eslint": "7.14.1","cspell": "8.9.1","stylelint": "16.6.1","husky": "9.0.11","commitlint": "19.3.0","cz-git": "1.9.3","commitizen": "4.3.0","@commitlint/config-conventional": "19.2.2"}

如有不完整的地方欢迎大家的反馈,我会悉心听取不断补足

http://www.dtcms.com/a/593215.html

相关文章:

  • 网站制作专业wordpress创建模板
  • 修改visio中默认的框图以及文字格式
  • java使用poi-tl模版+vform自定义表单生成word,使用LibreOffice导出为pdf
  • DVSSL证书vsOVSSL证书:详细区别与选择指南
  • 【Linux】CentOS 部署 IPFS
  • 声网选择性注意力锁定如何在嘈杂环境中守护特殊儿童?
  • RPA 财务自动化:核心应用场景,让财务工作降本增效提质
  • 打开高价值应用新窗口:人工智能场景培育与开放的关键举措
  • 网站建设改版攻略wordpress置顶的样式
  • 电商网站建设如何做游戏用什么电脑系统下载网站好
  • 景安做网站教程郴州365网
  • 日志监控MDC
  • 软考 系统架构设计师系列知识点之杂项集萃(195)
  • ArcGIS JSAPI 学习教程 - 场景可视区域(SceneView visibleArea)显示以及过滤要素应用
  • 肖特二极管电路设计应用
  • 天津做网站就到徽信xiala5手机兼职在哪个网站做
  • 扑灭斗殴的火苗:AI智能守护如何为校园安全保驾护航
  • 3DGS致密化操作中的梯度计算
  • 深度学习实战(基于pytroch)系列(八)softmax回归基于pytorch的代码实现
  • Redis进阶
  • 做采购 通常在什么网站看邢台市人事考试网
  • 构筑码头数字防线:视频汇聚平台EasyCVR全方位码头海岸线监管方案
  • 计算机理论基础学习Day19
  • 金仓数据库运维优化实践:从成本中心到效能引擎的转型之路
  • 招标网站哪个好用seo指什么
  • Java面试题1:Java 中 Exception 和 Error 有什么区别?
  • MacX DVD Ripper Pro for Mac v6.8.2 安装教程|MacDVD转换软件怎么安装?
  • 【rkyv】 Rust rkyv 库全面指南
  • 【Rust 探索之旅】Rust 性能优化实战指南:从编译器到并发的完整优化方案(附京东/华为云真实案例)
  • 做网站除了域名还要买什么网站搭建dns有用吗