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())
相关推荐
之歆8 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
Maimai108088 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong8 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
卡卡军11 小时前
agmd 1.0 重磅升级——Rust 重写,性能起飞
javascript·rust
Larcher11 小时前
🔥 告别抓瞎:用 Claude Code (cc) 优雅接手与维护已有项目
javascript·机器学习·前端框架
JYeontu11 小时前
轮播图不够惊艳?试下这个立体卡片轮播图
前端·javascript·css
亲亲小宝宝鸭11 小时前
如何监听DOM尺寸的变化?element-resize-detector 和 resizeObserver
前端·javascript
卷帘依旧14 小时前
Generator 全面解析 + async/await 深度对比
前端·javascript
weixin_4713830314 小时前
统一缩放单位基础(px、em、rem)
开发语言·javascript·ecmascript
yqcoder14 小时前
数据劫持的双雄:深入解析 Object.defineProperty 与 Proxy
开发语言·前端·javascript