什么是 VS Code 工作区 (workspace)?
Visual Studio Code 工作区 是在 VS Code 窗口(实例)中打开的一个或多个文件夹的集合。在大多数情况下,你只会打开一个文件夹作为工作区。然而,根据你的开发工作流程,你可以通过一种名为 多根工作区 (Multi-root workspaces) 的高级配置包含多个文件夹。
工作区的概念使 VS Code 能够:
- 配置仅适用于特定文件夹而不会影响其他文件夹的设置。
- 持久化仅在该工作区上下文中有效的任务和调试器启动配置。
- 存储和恢复与该工作区关联的 UI 状态(例如,已打开的文件)。
- 选择性地仅为该工作区启用或禁用扩展。
在 VS Code 文档、问题反馈和社区讨论中,你可能会看到“文件夹”和“工作区”这两个术语被交替使用。可以将工作区视为一个具有额外 VS Code 知识和功能项的项目根目录。
注意:也可以在没有工作区的情况下打开 VS Code。例如,当你通过操作系统的 文件 菜单选择一个文件来打开一个新的 VS Code 窗口时,你将不在工作区内。在这种模式下,VS Code 的某些功能会减少,但你仍然可以打开并编辑文本文件。
我该如何打开一个 VS Code “工作区”?
你可以通过 文件 > 打开文件夹... 菜单,然后选择一个文件夹来打开一个工作区。
或者,如果你从终端启动 VS Code,则可以将文件夹的路径作为第一个参数传递给 code 命令进行打开。例如,使用以下命令在 VS Code 中打开当前文件夹 (.):
code .
单文件夹工作区
除了使用 VS Code 打开文件夹外,你无需执行任何其他操作即可使其成为 VS Code 工作区。一旦打开文件夹,VS Code 会自动跟踪配置,例如你打开的文件或编辑器布局。当你再次在 VS Code 中打开该文件夹时,编辑器将恢复为你上次离开时的状态。
你还可以添加其他特定于文件夹的配置,例如工作区专用设置(相对于全局用户设置)、任务定义和调试启动文件(请参阅下方的 工作区设置 一节)。

在 VS Code 中打开的单文件夹工作区
多根工作区
多根工作区是 VS Code 的一项高级功能,允许你配置多个不同的文件夹作为同一工作区的一部分。你不再是打开一个文件夹作为工作区,而是打开一个列出了工作区所有文件夹的 <name>.code-workspace JSON 文件。例如:
{
"folders": [
{
"path": "my-folder-a"
},
{
"path": "my-folder-b"
}
]
}

在 VS Code 中打开的多根工作区
注意:打开一个文件夹与打开一个
.code-workspace文件在视觉上的差异可能很细微。为了提示你已经打开了.code-workspace文件,用户界面的一些区域(例如文件资源管理器的根目录)会在名称旁边显示一个额外的 (工作区) 后缀。
未命名的多根工作区
你可以灵活地在工作区中添加或删除文件夹。首先在 VS Code 中打开一个文件夹,然后根据需要添加更多文件夹。

用于在工作区中添加或删除文件夹的文件资源管理器上下文菜单
除非你已经打开了一个 .code-workspace 文件,否则当你第一次向工作区添加第二个文件夹时,VS Code 会自动创建一个未命名的工作区。在后台,VS Code 会自动为你维护一个 untitled.code-workspace 文件,其中包含当前会话中所有的文件夹和工作区设置。在你决定将其保存到磁盘之前,该工作区保持未命名状态。

在 VS Code 中打开的未命名多根工作区
注意:未命名工作区与已保存的工作区之间没有区别,唯一的区别是未命名工作区是为你方便而自动创建的,并且在保存之前它将始终保持恢复状态。当你关闭打开了未命名工作区的窗口时,VS Code 会(在询问你确认后)自动删除未命名工作区。
工作区设置
工作区设置允许你在已打开的工作区上下文中配置设置。工作区设置始终覆盖全局用户设置。它们实际存储在 JSON 文件中,其位置取决于你是将文件夹作为工作区打开,还是打开了一个 .code-workspace 文件。
请参阅设置文档,了解有关设置作用域及其文件位置的完整说明。
单文件夹工作区设置
当你将文件夹作为工作区打开时,工作区设置存储在 .vscode/settings.json 中。

将文件夹作为工作区打开时的设置编辑器
多根工作区设置
当你打开 .code-workspace 作为工作区时,所有工作区设置都会添加到 .code-workspace 文件中。
你仍然可以按根文件夹配置设置,设置编辑器将显示第三个设置作用域,称为 文件夹设置 (Folder Settings)。

打开多根工作区时的设置编辑器
按文件夹配置的设置会覆盖 .code-workspace 中定义的设置。
工作区任务和启动配置
与工作区设置特定于工作区类似,任务和启动配置也可以限定在工作区作用域内。
根据你是将文件夹作为工作区打开还是打开了 .code-workspace 文件,工作区任务和启动配置的位置要么在 .vscode 文件夹内,要么在 .code-workspace 文件内。此外,即使你已经打开了 .code-workspace 文件,任务和启动配置也始终可以在文件夹级别进行定义。
有关如何在 VS Code 中使用任务和启动配置的更全面概述,请参阅任务和调试章节。
常见问题
多根工作区相对于文件夹的优势是什么?
最明显的优势是,多根工作区允许你处理存储在磁盘上不同父文件夹中的多个项目。你可以从任何地方选取文件夹添加到工作区中。
即使你主要是在单个文件夹的项目中工作,你也可以从使用 .code-workspace 文件中受益。你可以在文件夹内存储多个 .code-workspace 文件,以根据场景提供项目某些方面的特定视图(例如 client.code-workspace、server.code-workspace 以从文件资源管理器中过滤掉不相关的文件夹)。由于 .code-workspace 文件支持 folders 部分的相对路径,这些工作区文件适用于任何人,无论该文件夹存储在哪里。
最后,如果对于某些项目,你希望应用相同的工作区设置或任务/启动配置,请考虑将它们添加到 .code-workspace 文件中,并从该工作区添加或删除这些文件夹。
为什么 VS Code 在重启时会恢复所有未命名工作区?
未命名工作区的设计初衷是让你显式决定是否保留它们。第一次创建未命名工作区时,VS Code 会将指定的文件夹添加到工作区文件中,并添加所有现有的工作区设置。这些用户数据始终会被恢复并显示在 VS Code 窗口中,直到未命名工作区被保存或删除。
如何删除未命名工作区?
你可以通过关闭其窗口并在提示保存未命名工作区时选择取消(或拒绝保存)来删除未命名工作区。
我可以在没有文件夹的情况下使用多根工作区吗?
可以将 .code-workspace 文件的 folders 部分留空,这样你将得到一个不显示任何根文件夹的 VS Code 实例。在这种情况下,你仍然可以存储工作区设置,甚至可以存储任务或启动配置。
VS Code 支持项目或解决方案吗?
VS Code 没有其他开发工具(例如 Visual Studio IDE)中定义的“项目”或“解决方案”概念。你可能会在 VS Code 文档中看到“项目”一词,但它通常指“你正在处理的事物”。根据你的编程语言或框架,工具集本身可能会支持某种称为“项目”的东西,以帮助定义构建配置或枚举包含的文件。