什么是 VS Code 工作区?
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 文档中看到“项目”这个术语,但它通常指“你正在处理的事情”。根据你的编程语言或框架,工具集本身可能支持名为“项目”的功能,以帮助定义构建配置或枚举包含的文件。