deno.com
本页内容

deno outdated

命令行用法

deno outdated [OPTIONS] [filters]...

查找并更新过时依赖项。默认情况下,只显示过时的依赖项。

显示过时依赖项

deno outdated
deno outdated --compatible

将依赖项更新到最新的 semver 兼容版本

deno outdated --update

将依赖项更新到最新版本,忽略 semver 要求

deno outdated --update --latest

可以使用过滤器来选择要操作的包。过滤器可以包含通配符 (*) 以匹配多个包。

deno outdated --update --latest "@std/*"
deno outdated --update --latest "react*"

请注意,过滤器作用于在 deno.json / package.json 中配置的别名,而非实际包名:例如,如果在 deno.json 或 package.json 中有 "foobar": "npm:react@17.0.0",则过滤器 "foobar" 会将 npm:react 更新到最新版本。

deno outdated --update --latest foobar

过滤器可以组合使用,也可以使用否定过滤器来排除结果

deno outdated --update --latest "@std/*" "!@std/fmt*"

可以指定要更新到的特定版本要求

deno outdated --update @std/fmt@^1.0.2

选项 Jump to heading

--compatible Jump to heading

只考虑满足 semver 要求的版本。

--interactive Jump to heading

短标志:-i

交互式选择要更新的依赖项。

--latest Jump to heading

考虑最新版本,无论 semver 限制如何。

--recursive Jump to heading

短标记:-r

包含所有工作区成员。

--update Jump to heading

短标志: -u

更新依赖项版本。

依赖管理选项 Jump to heading

--frozen Jump to heading

如果锁定文件过期,则报错。

--lock Jump to heading

检查指定的锁定文件。(如果未提供值,则默认为 “./deno.lock”)。

--no-lock Jump to heading

禁用锁定文件的自动发现。

检查过时依赖项 Jump to heading

outdated 子命令检查 deno.jsonpackage.json 文件中列出的 NPM 和 JSR 依赖项的新版本,并显示可以更新的依赖项。工作区得到全面支持,包括某些成员使用 package.json 而另一些成员使用 deno.json 的工作区。

例如,一个带有 deno.json 文件的项目

{
  "imports": {
    "@std/fmt": "jsr:@std/fmt@^1.0.0",
    "@std/async": "jsr:@std/async@1.0.1",
    "chalk": "npm:chalk@4"
  }
}

以及一个锁定文件,其中 @std/fmt 的版本为 1.0.0

$ deno outdated
┌────────────────┬─────────┬────────┬────────┐
│ Package        │ Current │ Update │ Latest │
├────────────────┼─────────┼────────┼────────┤
│ jsr:@std/fmt   │ 1.0.0   │ 1.0.3  │ 1.0.3  │
├────────────────┼─────────┼────────┼────────┤
│ jsr:@std/async │ 1.0.1   │ 1.0.1  │ 1.0.8  │
├────────────────┼─────────┼────────┼────────┤
│ npm:chalk      │ 4.1.2   │ 4.1.2  │ 5.3.0  │
└────────────────┴─────────┴────────┴────────┘

Update 列显示最新的 semver 兼容版本,而 Latest 列显示最新版本。

请注意,jsr:@std/async 被列出,即使没有 semver 兼容版本可以更新。如果您只想显示有新兼容版本的包,可以传递 --compatible 标志。

$ deno outdated --compatible
┌────────────────┬─────────┬────────┬────────┐
│ Package        │ Current │ Update │ Latest │
├────────────────┼─────────┼────────┼────────┤
│ jsr:@std/fmt   │ 1.0.0   │ 1.0.3  │ 1.0.3  │
└────────────────┴─────────┴────────┴────────┘

jsr:@std/fmt 仍然被列出,因为它可以兼容地更新到 1.0.3,但 jsr:@std/async 不再显示。

更新依赖项 Jump to heading

outdated 子命令也可以通过 --update 标志来更新依赖项。默认情况下,它只会将依赖项更新到 semver 兼容的版本(即,它不会更新到破坏性版本)。

$ deno outdated --update
Updated 1 dependency:
 - jsr:@std/fmt 1.0.0 -> 1.0.3

要更新到最新版本(无论是否 semver 兼容),请传递 --latest 标志。

$ deno outdated --update --latest
Updated 3 dependencies:
 - jsr:@std/async 1.0.1 -> 1.0.8
 - jsr:@std/fmt   1.0.0 -> 1.0.3
 - npm:chalk      4.1.2 -> 5.3.0

选择包 Jump to heading

outdated 子命令还支持选择要操作的包。这在使用或不使用 --update 标志时都有效。

$ deno outdated --update --latest chalk
Updated 1 dependency:
 - npm:chalk 4.1.2 -> 5.3.0

可以传递多个选择器,并且支持通配符 (*) 或排除 (!)。

例如,要更新所有带有 @std 范围的包,除了 @std/fmt

$ deno outdated --update --latest "@std/*" "!@std/fmt"
Updated 1 dependency:
 - jsr:@std/async 1.0.1 -> 1.0.8

请注意,如果使用通配符,您可能需要用引号将参数括起来,以防止 shell 尝试扩展它们。

更新到特定版本 Jump to heading

除了选择要更新的包之外,--update 标志还支持选择新版本,通过在 @ 后面指定版本。

❯ deno outdated --update chalk@5.2 @std/async@1.0.6
Updated 2 dependencies:
 - jsr:@std/async 1.0.1 -> 1.0.6
 - npm:chalk      4.1.2 -> 5.2.0

工作区 Jump to heading

在工作区设置中,默认情况下 outdated 只对当前工作区成员进行操作。

例如,给定一个工作区

{
  "workspace": ["./member-a", "./member-b"]
}

运行

deno outdated

./member-a 目录执行时,将只检查 ./member-a/deno.json./member-a/package.json 中列出的过时依赖项。

要包含所有工作区成员,请传递 --recursive 标志(也接受 -r 简写形式)

deno outdated --recursive
deno outdated --update --latest -r

您找到所需内容了吗?

隐私政策