“npx tsc --version”报告虚拟机内不同的TypeScript版本

LaV*_*che 4 node.js npm typescript tsc npx

我希望能够npx tsc在我的主机 + 来宾操作系统上运行我的项目。但是来宾使用的是不同(旧)版本的tsc- 我不确定它来自哪里。

我的设置:

  • 主机操作系统:Windows 10
  • 来宾操作系统:Debian 9
  • 我正在使用 VirtualBox,并且来宾正在使用 VirtualBox 的“共享文件夹”功能挂载主机的文件 - 因此它没有项目文件的单独副本 - 我的项目始终通过共享文件夹访问。
  • 我没有在主机或来宾操作系统上全局安装 Typescript(npm -g)(为了确认这一点,npm -g ls typescript在主机+来宾上运行都显示“空”,而单独运行“tsc”不起作用,正如预期的那样)。

我有一个使用 NPM 安装到项目中的 TypeScript 3.3.3333 项目。

在 Windows 主机操作系统上,当我cd到项目文件夹并运行时:

  • npm ls typescript我看到输出:(typescript@3.3.3333如预期)
  • npx tsc --version我看到输出:(Version 3.3.3333如预期)

在 Linux 来宾操作系统中,当我cd进入项目文件夹并运行时:

  • npm ls typescript我看到输出:(typescript@3.3.3333如预期)
  • npx tsc --version我看到输出:message TS6029: Version 1.5.3意外!

所以我无法npx tsc在来宾中运行以编译我的代码,因为它不支持我的一些较新的 tsconfig 设置。

这个 tsc 1.5.3 版本来自哪里,我该如何摆脱它?

或者是否有一些我可以在主机上运行的替代 NPM 命令,它将安装一个可tsc用于 Windows + Linux 的项目?

此外,我的项目根目录上方的父文件夹都没有node_modules文件夹(但当然我的项目根目录确实有它的 node_modules 子文件夹)。

Est*_*ask 12

为简洁起见,称为 TypeScript 二进制文件tsc。当它不是全局安装时,npx无法知道包tsc是指tsc二进制文件typescriptnpx tsc指的是已弃用的tsc

可以解决此问题的一种方法是明确指定包名称:

npx -p typescript tsc
Run Code Online (Sandbox Code Playgroud)

而这里的实际问题是该项目依赖于全局 TypeScript 安装。typescript在项目依赖项中编写项目并在 package.json NPM 脚本中引用本地安装是很常见的:

...
"scripts": {
  "build": "tsc"
},
"devDependencies": {
  "typescript": "~3.3.0"
"
...
Run Code Online (Sandbox Code Playgroud)

  • 谢谢,看来`npx -p typescript tsc` 满足了我的需求,并正确报告了 3.3.3333 版。我很好奇旧的“tsc”包是如何运行的?因为我没有在项目中或全局安装它,并且字符串“tsc”甚至在我的 package.json 或 package-lock.json 文件中的任何地方都不存在。node_modules 下也没有“tsc”文件夹。另外`npx tsc --version` 报告了`消息 TS6029: Version 1.5.3` - 这似乎不是“tsc”包的版本号?(它的版本号使用不同的格式)。 (4认同)
  • 我在主机或来宾文件系统上的任何地方都找不到任何“tsc”包。npx 是否会临时下载副本并在运行后将其删除?(当我运行它时,我看到一条消息 `npx: installed 1 in 1.998s`)否则“tsc”包文件可能来自哪里? (2认同)