在 vscode 的 NPM SCRIPTS 面板点击执行后脚本失败

文章目录

背景

如果你的项目的 package.json 配置了 script 字段,那么在 VSCode - Explorer 最下面一般可以看到一个收起的 NPM SCRIPTS 面板,这里会列出 script 字段中配置的所有 npm 命令。

hover到每个脚本上,会出现一个 debug 按钮,一个 run 按钮。点击即可调试或者执行 npm 脚本。

但是如果你配置过 vscode 的默认终端,那么直接点击 run 时会执行失败。

比如我就是将 vscode 终端自定义成了本地的 git-bash

json 复制代码
// VSCode/User/settings.json

"terminal.integrated.profiles.windows": {
  "git-bash": {
    "path": "D:\\Dev\\Git\\PortableGit\\bin\\sh.exe",
  },
},
"terminal.integrated.defaultProfile.windows": "git-bash",

报错

点击 run 后,就有以下报错:

bash 复制代码
 *  Executing task: npm run test 

/d: /d: Is a directory

 *  The terminal process "D:\Dev\Git\PortableGit\bin\sh.exe /d /c npm run test" terminated with exit code: 126. 
 *  Terminal will be reused by tasks, press any key to close it. 

这不是 npm test 脚本问题,而是 NPM Scripts 面板触发任务时用了错误的 shell 组合。

日志里是:

  • 可执行程序:sh.exe
  • 参数:/d /c(这是 cmd.exe 的参数)

所以才会出现 /d: Is a directory

解决办法1

把上面提到的自定义默认终端设置给删掉,使其恢复成默认的配置(应该是 cmd)。

或者把上面的配置改成 powershell 或者 cmd 应该也行。

解决办法2

如果你想和我一样保留上面自定义默认终端配置为 git-bash,那么手动配置"自动执行脚本"所使用的终端为兼容的终端(比如 cmd 或者 powershell):

json 复制代码
// VSCode/User/settings.json

"terminal.integrated.automationProfile.windows": {
  "path": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell.exe"
},

如果修改并报存后不起作用,可以重启 vscode,或者 Ctrl + Shift + P 执行 Developer: Reload Window 命令重新加载vscode窗口,然后试着重新点击 run 按钮。此时应该是能正常执行的。

相关推荐
西门吹牛12 小时前
Pycharm编译器中部署了pyqt5,Qtdesigner无法打开了,解决方案
ide·qt·pycharm
#君君#13 小时前
ros2 下VSCode 中显示波浪线(找不到定义)原因
ide·vscode·编辑器
芋头莎莎13 小时前
ESP32 +VSCode与搭建开发环境教程
vscode·单片机
大黄说说13 小时前
匹配表达式 vs. Switch语句:现代PHP中的条件逻辑重构
android·ide·android studio
ycjunhua13 小时前
windows 安装 Claude Code
ide·windows
HeeRiver1 天前
VSCode调用deepseek-v4-pro/flash api的方法
ide·vscode·api·deepseek-v4
小菜鸟阿呆yu1 天前
【pycharm】安装包例如pymysql
ide·python·pycharm
森林猿1 天前
IDEA-控制台乱码
java·ide·intellij-idea
H Journey1 天前
Windows + VSCode + CMake 编译
windows·vscode·cmake
三品吉他手会点灯1 天前
STM32 VSCode 开发-与STM32CubeMX协同开发环境搭建
vscode·stm32·单片机·嵌入式硬件