lint-staged 无法提交代码 this.options.fields ??= {};SyntaxError: Unexpected token '??=

项目重新安装依赖以后,突然无法重新提交代码了, 纳尼!!!!

基础环境

makefile 复制代码
node: 14.21.3
"lint-staged": "^13.2.2"

报错信息

shell 复制代码
 ******* pre-commit 钩子触发 **************
file:///D:/projects/carbon-credit/node_modules/listr2/dist/index.js:206
    this.options.fields ??= {};
                        ^^^                    
SyntaxError: Unexpected token '??='
at Loader.moduleStrategy (internal/modules/esm/translators.js:149:18)
husky - pre-commit hook exited with code 1 (error)

从报错结果分析, 是配置了 pre-commit 钩子,执行了什么动作, 然后提示,无法提交 commit 信息

.husky/pre-commit

bash 复制代码
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
echo ''
echo -e "\e[0;32m ******* pre-commit 钩子触发 **************\e[0m"
echo ''

npx --no-install lint-staged

这里执行了 lint-staged

分析过程

  1. 查看是哪个包依赖了 listr2, 不是直接从node_modules 里面搜搜, 看lock文件
  2. 之前是好的, 说明一定是因为某个环境的变化导致了这个问题的发生。

既然定位到了 lint-staged , 则猜测,是 lint-staged 依赖 listr2, 然后 listr2 包语法发生了变化,导致不兼容

查看 lint-staged 的 issue-1315 , 找到类似答案。 node 版本必须为 16 + 才行。

nvm 切换node 版本为 16.20.2

再次提交代码 git commit -m 'feat: 初始化项目'

可以了~

解决办法

  • 方式1: node 升级到16
  • 方式2: 公司业务环境限制,无法升级到node 16+的, 降级lint-staged 从 13.2.213.2.0
相关推荐
Li_Ning2111 分钟前
【接口重复请求】axios通过AbortController解决页面切换过快,接口重复请求问题
前端
胡八一1 小时前
Window调试 ios 的 Safari 浏览器
前端·ios·safari
Dontla1 小时前
前端页面鼠标移动监控(鼠标运动、鼠标监控)鼠标节流处理、throttle、限制触发频率(setTimeout、clearInterval)
前端·javascript
再学一点就睡1 小时前
深拷贝与浅拷贝:代码世界里的永恒与瞬间
前端·javascript
CrimsonHu1 小时前
B站首页的 Banner 这么好看,我用原生 JS + 三大框架统统给你复刻一遍!
前端·javascript·css
Enti7c1 小时前
前端表单输入框验证
前端·javascript·jquery
拉不动的猪1 小时前
几种比较实用的指令举例
前端·javascript·面试
麻芝汤圆2 小时前
MapReduce 的广泛应用:从数据处理到智能决策
java·开发语言·前端·hadoop·后端·servlet·mapreduce
与妖为邻2 小时前
自动获取屏幕尺寸信息的html文件
前端·javascript·html
哟哟耶耶3 小时前
React-01React创建第一个项目(npm install -g create-react-app)
前端·javascript·react.js