husky 9.0升级指南

新年伊始,我们带来了激动人心的更新!

注意:使用安装方式husky@latest可以获得之后发布的错误修复程序。

介绍husky init

v8

复制代码
npm pkg set scripts.prepare="husky install"
npm run prepare
npx husky add .husky/pre-commit "npm test"

v9

现在将 Husky 添加到项目中比以往任何时候都更加简单。只需一行代码即可完成与上述相同的操作。无需再阅读文档即可上手。

复制代码
npx husky init

添加新钩子

v8

复制代码
npx husky add  .husky/pre-commit "npm test"
git add --chmod=+x .husky/pre-commit # On Windows

v9

添加钩子就像创建一个文件一样简单。您可以使用您喜欢的编辑器、脚本或基本echo命令来完成此操作。例如,在 Linux/macOS 上:

复制代码
echo "npm test" > .husky/pre-commit

进一步缩小尺寸

v8已经是体积最小的 Git hooks 管理器了,大约只有6kB

v9更进一步,将大小减少到仅3kB,这很可能使它成为工具包中最小的开发依赖项。

为了让您对它的体积大小有个概念,项目中最大的文件是 MIT 许可证 😄

更多精彩内容敬请期待

更多功能正在开发中v9,敬请期待🙌

其他变化

  • 利用 CI 和 npm增强安全性 --provenance,实现更安全的发布。
  • 新增**$XDG_CONFIG_HOME** 支持。迁移~/.huskyrc~/.config/husky/init.sh集中式配置。
  • 修复了 Windows 创建的钩子的权限问题;它们不再需要是可执行的。
  • 已移除husky install。请使用huskyhusky some/dir实现相同功能(将添加弃用通知)。
  • 修改了缺少该参数时的行为.git;现在会触发警告而不是失败。
  • 已替换HUSKY_DEBUG=1HUSKY=2用于调试。
  • 更新了 Husky API 的模块使用方法。
  • 已过渡到ESM模块使用。
  • 已停止支持 Node 14 和 16。
  • 文档已更新。

如何迁移

v9向后兼容v8,允许您以后自由升级和迁移您的钩子。

以下是迁移步骤:

package.json

复制代码
{
  "scripts": {
-   "prepare": "husky install"
+   "prepare": "husky"
  }
}

.husky/pre-commit

复制代码
- #!/usr/bin/env sh
- . "$(dirname -- "$0")/_/husky.sh"
npm test 

注意:sh即使设置了 shebang,也会用于运行 hooks。

如果您是将其husky作为模块使用:

复制代码
- const husky = require('husky')
- // ...
+ import husky from 'husky'
+ console.log(husky())
相关推荐
松小白song3 分钟前
机器人路径规划算法之Dijkstra算法详解+MATLAB代码实现
前端·javascript·算法
optimistic_chen7 分钟前
【Vue3 入门】掌握这些才能优雅上手
前端·javascript·vue.js·前端框架·visual studio code
认真的小羽❅7 分钟前
JavaScript完全指南:从入门到精通
开发语言·javascript·ecmascript
程序员库里1 小时前
TipTap简介
前端·javascript·面试
关中老四1 小时前
【js/web甘特图插件MZGantt】如何使用外部弹框添加和修改任务(updRows方法使用说明)
前端·javascript·甘特图·甘特图插件
兆子龙1 小时前
Vite 打包优化实战:从 12.17M 到 7.95M 的瘦身之旅
javascript
confiself1 小时前
A2UI实时渲染展示
开发语言·javascript·css
014-code2 小时前
Vue 生命周期完全指南
前端·javascript·vue.js
冴羽yayujs2 小时前
资深前端都在用的 9 个调试偏方
前端·javascript·调试