我正在编写一个内部工具,它比较项目中安装的版本,只允许通过某些版本。为此,我必须检查 yarn.lock
中解决的版本。文件,因为 package.json 文件有一个 semver 范围,而不是特定版本,它不会告诉你依赖项的依赖关系。
我尝试使用 yarn list
命令,但它也打印 semver 范围并且很难解析(即使使用 --json
选项)。
所以yarn.lock
似乎是唯一的方法。我知道yarn.lock
可能有同一个包的不同版本,在这种情况下,我只想要安装的版本。node_nodules
(必须只是其中之一)。我不知道如何解析锁定文件。
我能想到的另一种方法实际上是进入 node_modules
文件夹并检查 package.json
中的版本的包。
以上选项对我来说都不干净。有什么方法可以让我尽可能轻松、干净地知道特定包的已解决版本(前提是我知道包的名称并且知道它已安装)?
更新 :
我实际上想要已安装包的所有版本(即使它们在依赖关系树中很深)。
最佳答案
由于您知道包的名称,请执行以下操作:
yarn list --pattern <package_name>
上面的命令将为您提供任何深度的软件包的所有已安装版本。例如,我有不同版本的 camelcase
图书馆安装在不同的深度。运行命令:yarn list --pattern "camelcase"
,这是输出:yarn list v1.22.5
├─ camelcase@6.2.0
└─ yargs-parser@13.1.2
└─ camelcase@5.3.1
关于javascript - 如何从 yarn.lock 知道当前安装包的版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60454251/