deno outdated
Command line usage
deno outdated [OPTIONS] [filters]...
Find and update outdated dependencies. By default, outdated dependencies are only displayed.
Display outdated dependencies:
deno outdated
deno outdated --compatible
Update dependencies to latest semver compatible versions:
deno outdated --update
Update dependencies to latest versions, ignoring semver requirements:
deno outdated --update --latest
Filters can be used to select which packages to act on. Filters can include wildcards (*) to match multiple packages.
deno outdated --update --latest "@std/*"
deno outdated --update --latest "react*"
Note that filters act on their aliases configured in deno.json / package.json, not the actual package names: Given "foobar": "npm:react@17.0.0" in deno.json or package.json, the filter "foobar" would update npm:react to the latest version.
deno outdated --update --latest foobar
Filters can be combined, and negative filters can be used to exclude results:
deno outdated --update --latest "@std/*" "!@std/fmt*"
Specific version requirements to update to can be specified:
deno outdated --update @std/fmt@^1.0.2
Dependency management options Jump to heading
--lock
Jump to heading
Check the specified lock file. (If value is not provided, defaults to "./deno.lock").
--no-lock
Jump to heading
Disable auto discovery of the lock file.
Options Jump to heading
--compatible
Jump to heading
Only consider versions that satisfy semver requirements.
--interactive
Jump to heading
Short flag: -i
Interactively select which dependencies to update.
--latest
Jump to heading
Consider the latest version, regardless of semver constraints.
--recursive
Jump to heading
Short flag: -r
include all workspace members.
--update
Jump to heading
Short flag: -u
Update dependency versions.
检查过期依赖 Jump to heading
outdated
子命令检查 deno.json
或 package.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
┌────────────────┬─────────┬────────┬────────┐
│ 包名称 │ 当前版本 │ 更新版本 │ 最新版本 │
├────────────────┼─────────┼────────┼────────┤
│ 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 │
└────────────────┴─────────┴────────┴────────┘
更新版本
列显示最新的 semver 兼容版本,而 最新版本
列显示最新版本。
注意,尽管没有可以更新到的 semver 兼容版本,jsr:@std/async
仍然被列出。如果您希望仅显示具有新兼容版本的包,可以传递 --compatible
标志。
$ deno outdated --compatible
┌────────────────┬─────────┬────────┬────────┐
│ 包名称 │ 当前版本 │ 更新版本 │ 最新版本 │
├────────────────┼─────────┼────────┼────────┤
│ 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
更新了 1 个依赖:
- jsr:@std/fmt 1.0.0 -> 1.0.3
要更新到最新版本(无论是否兼容 semver),请传递 --latest
标志。
$ deno outdated --update --latest
更新了 3 个依赖:
- 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
更新了 1 个依赖:
- npm:chalk 4.1.2 -> 5.3.0
可以传递多个选择器,并且也支持通配符(*
)或排除(!
)。
例如,要更新所有具有 @std
范围的包,除了 @std/fmt
:
$ deno outdated --update --latest "@std/*" "!@std/fmt"
更新了 1 个依赖:
- 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
更新了 2 个依赖:
- 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"]
}
从 ./member-a
目录运行
deno outdated
将仅检查 ./member-a/deno.json
或 ./member-a/package.json
中列出的过期依赖。
要包括所有工作区成员,请传递 --recursive
标志(-r
简写也被接受)
deno outdated --recursive
deno outdated --update --latest -r