2023 年 1 月 (版本 1.75)
更新 1.75.1:此更新解决了这些问题。
下载:Windows:x64 Arm64 | Mac:通用 Intel Apple Silicon | Linux:deb rpm tarball Arm snap
欢迎来到 Visual Studio Code 2023 年 1 月发布版本。此版本中有许多更新,希望您会喜欢,其中一些主要亮点包括:
- 配置文件 - 创建和共享配置文件,以配置扩展、设置、快捷方式等。
- VS Marketplace 签名 - 已发布的扩展现在默认进行代码签名。
- 辅助功能改进 - 终端屏幕阅读器模式,新键盘快捷方式。
- 更轻松的多视图调整大小 - 拖动布局角落以同时调整多个视图的大小。
- 树视图搜索历史记录 - 快速重新运行树视图中的先前搜索。
- 更好的终端链接检测 - 检测包含空格、括号、行和列格式的链接。
- 新的 Git 命令 - 在 VS Code 中暂存已暂存的更改并删除远程标签。
- Dark+ 和 Light+ V2 主题 - 试用实验性颜色主题,并告诉我们您的想法。
- Jupyter Notebook 主题 - 在 Web 上使用笔记本,如何管理 Jupyter 内核。
- VS Code 中的 AI 工具 - 了解使用 GitHub Copilot 实现的 AI 驱动的代码补全。
如果您想在线阅读这些发布说明,请访问 code.visualstudio.com 上的更新页面。
Insiders:想尽快试用新功能吗?您可以下载每夜构建的 Insiders 版本,并在最新更新可用时立即试用。
内务管理
在之前的发布说明中,团队报告了我们的内务管理工作,我们希望在此也这样做。
正如我们在 2022 年 11 月宣布的那样,我们利用 12 月对 GitHub 问题和拉取请求进行了内务管理(请参阅我们的问题清理指南)。在我们所有的仓库中,我们实现了开放问题和拉取请求净减少 3637 个。不出所料,大部分减少发生在我们的前 5 个仓库中:microsoft/vscode (2520)、microsoft/vscode-jupyter (374)、microsoft/vscode-remote-release (278)、microsoft/vscode-python (220) 和 microsoft/vscode-pull-request-github (160)。
辅助功能
差异导航改进
“转到下一个/上一个更改”现在具有音频提示,指示行是插入、删除还是修改。此外,还会选择更改的行,以便屏幕阅读器可以朗读。
终端辅助模式
“终端:聚焦可访问缓冲区” (⌥F2 (Windows Alt+F2, Linux Shift+Alt+F2)) 命令允许屏幕阅读器通过键盘在终端缓冲区中导航。
终端辅助帮助
类似于编辑器中的“显示辅助功能帮助”命令,“终端:显示终端辅助功能帮助” () 命令为屏幕阅读器用户提供了重要信息。
工作区信任编辑器快捷方式
为了提高工作区信任编辑器的键盘辅助功能(可以通过“工作区:管理工作区信任”打开),您现在可以使用 Ctrl/Cmd+Enter
通过键盘切换当前工作区的信任,或使用 Ctrl/Cmd+Shift+Enter
切换父文件夹的信任。
设置编辑器指示器上的改进键盘导航
对于具有多个指示器的设置,例如“在其他位置修改”指示器和“默认值已更改”指示器,现在可以使用左右箭头键在指示器之间导航。此更改允许用户通过单次按下 Tab
键来退出指示器。
配置文件
我们很高兴地宣布,配置文件功能现已在 VS Code 中正式推出。配置文件可以包括扩展、设置、键盘快捷方式、UI 状态、任务和用户片段。您可以针对不同的开发场景(如数据科学、文档编写)或多种编程语言(如 Python 或 Java)自定义 VS Code。如果您有基于工作流(如“工作”或“演示”)的不同 VS Code 设置,您也可以将它们保存为不同的配置文件。您可以同时打开多个工作区(文件夹),并应用不同的配置文件。
下图演示了使用为工作设置定制的“工作”配置文件打开的文件夹。
您还可以导出和导入配置文件,与您的同事、朋友或学生共享,帮助他们开始使用 VS Code。
以下视频演示了如何使用 GitHub gist 导出配置文件以与他人共享。接收配置文件链接的用户可以在VS Code for the Web中预览共享配置文件,并将其导入到本地 VS Code 实例中。
注意:配置文件目前不适用于远程场景,如GitHub Codespaces,但我们正在努力启用此功能。您可以在问题 #165247 中跟踪进展。
工作台
改进的多视图调整大小支持
您现在可以通过拖动视图的角落同时调整多个视图的大小。
改进的网格布局
如果编辑器最小化,当调整整个工作台或侧边栏大小时,网格现在将保持该状态。在下面的短视频中,右侧最小化编辑器的宽度在整个编辑器区域展开时保持不变。
从“自定义布局”命令恢复默认设置
当通过触发命令或使用自定义标题栏中的布局控件使用自定义“自定义布局”命令时,您可以使用布局控件右上角的还原箭头按钮“恢复默认设置”。
从面板管理面板对齐
您现在可以直接从面板上下文菜单调整面板对齐方式,就像调整面板位置一样。
简化的首选项菜单
我们简化了全局设置的“首选项”菜单,并将选项组织成更符合逻辑的顺序和分组。
树查找历史记录
树视图内的“查找”控件现在支持历史导航。您可以使用向上/向下箭头键浏览以前搜索的历史记录。
树查找连续匹配
树视图“查找”控件现在支持连续匹配以及现有的“模糊”匹配。在下面的视频中,最初搜索 "src"
会有诸如 "resource"
的匹配项。当通过“模糊匹配”切换按钮禁用“模糊”匹配时,只会突出显示包含连续文本 "src"
的文本。
按页滚动列表
新增设置 workbench.list.scrollByPage
,允许您配置当直接点击滚动条时,列表是否应该按页滚动。
列表类型导航模式
新的 workbench.list.typeNavigationMode
设置允许您配置列表的类型导航模式。默认情况下(设置值 automatic
),导航会在您键入时在列表和树中发生。如果您只想在特定时间启用导航,可以将 typeNavigationMode
设置为 trigger
,并且列表只会在运行 list.triggerTypeNavigation
命令后进入类型导航模式。
命令 list.triggerTypeNavigation
默认没有键盘绑定,但您可以添加自己的键盘绑定。例如,如果您希望在按下 /
键后进入类型导航模式,您可以添加一个键盘绑定,例如
{
"key": "/",
"command": "list.toggleKeyboardNavigation",
"when": "listFocus"
}
打开大型文件的新确认提示
为防止意外打开非常大的文件,特别是在远程环境中,由于网络传输可能产生实际成本,因此在打开文件前会显示确认提示。该限制可以通过新的 workbench.editorLargeFileConfirmation
设置进行修改,并且根据打开本地文件或远程文件有不同的默认值。
文件观察器支持 files.watcherExclude glob 模式
files.watcherExclude
设置支持 glob 模式,用于文件观察器的强大排除规则。然而,用于文件观察的库本身不支持 glob 模式。在此里程碑中,我们贡献了对排除项的 glob 模式支持,以实现更高效的资源使用,尤其是在 Linux 上。
对于 Linux,如果您遇到文件监视问题,请参阅此常见问题解答条目以获取更多信息。
键盘快捷方式编辑器改进
显示贡献键盘绑定的扩展
键盘快捷方式编辑器现在在“源”列中显示贡献键盘绑定的扩展。您可以选择扩展名称以打开扩展的详细信息页面。
您还可以使用扩展上下文菜单中提供的“扩展键盘快捷方式”操作来搜索扩展贡献的任何键盘快捷方式。
显示 when 子句属性的上下文键建议
键盘快捷方式编辑器现在会为 when
属性显示上下文键建议。您可以使用 Ctrl+Space
快捷键触发建议。
搜索带有组合键的键盘快捷方式
键盘快捷方式编辑器现在支持搜索带有组合键的键盘快捷方式。例如,"Ctrl+K"
也会显示所有以 Ctrl+K
作为第一个组合键的键盘快捷方式。
设置 Shell 环境变量解析超时
一个新的设置 application.shellEnvironmentResolutionTimeout
(仅限 macOS 和 Linux)允许您在需要解析 Shell 环境时增加超时时间。默认情况下,VS Code 会等待最多 10 秒来解析环境,但在某些更复杂的 Shell 设置情况下,这可能不够时间。
有关 VS Code 如何解析 shell 环境的更多信息,请参阅此常见问题解答条目。
新增 VSCODE_RESOLVING_ENVIRONMENT 环境变量
当 VS Code 正在解析用户 shell 环境时,它现在将一个新的环境变量 VSCODE_RESOLVING_ENVIRONMENT
设置为 1
。这对于需要知道它们是否正在 shell 环境解析上下文中运行的用户脚本(例如,在 .bashrc
中)非常有用。
更新后更易选择退出发布说明
您现在可以直接从发布说明编辑器中选择在每次更新后不再阅读发布说明。这会反映并更新 update.showReleaseNotes
设置。
编辑器
建议选择模式
新增设置 (editor.suggest.selectionMode
),允许您配置建议是随您键入自动选择还是通过触发字符选择。
默认设置是始终选择最佳建议,以便按下 Enter
或 Tab
键即可插入。如果您不希望自动选择建议,请将值设置为 never
、whenQuickSuggestion
或 whenTriggerCharacter
。使用这些设置值时,建议仍会显示,但不会自动选择,您可以使用箭头键选择一个。
请注意,此设置仅适用于自动建议,不适用于您通过 Ctrl+Space
显式触发的建议。
代码操作列表现在可滚动
有些扩展生成了很长的代码操作列表。如果没有足够的空间来渲染所有代码操作,您现在可以滚动浏览列表。
颜色修饰器限制
编辑器中显示的颜色修饰器数量限制为 500 个。这是为了防止在打开包含大量颜色的文件时出现性能问题。此限制现在可以通过 editor.colorDecoratorsLimit
设置进行配置。
编辑器查找转到匹配项
当“查找”控件打开时,新的“转到匹配项...”命令允许您根据计数跳转到文件中的特定匹配项。当您有大量匹配项并希望跳转到特定匹配项时,此功能非常有用。
重新设计的行内建议工具栏
在此里程碑中,我们重新设计了行内建议工具栏,使其更加紧凑且易于使用。它具有快速循环浏览替代建议以及完全或逐字接受建议的按钮。
在下面的视频中,用户查看了GitHub Copilot在注释提示上提供的两个建议,然后逐步接受了第一个 console
和 console.log
的下一个单词。
设置 "editor.inlineSuggest.showToolbar": "always"
可用于在有行内建议时始终显示工具栏。
我们还添加了逐字接受/撤销建议的默认键盘绑定(Ctrl+Arrow Left/Arrow Right
)。
终端
新默认键盘绑定
已添加以下默认键盘绑定,以提高高级终端功能的可发现性
打开检测到的链接 - Ctrl/Cmd+Shift+O
“打开检测到的链接”命令 (⇧⌘G (Windows, Linux Ctrl+Shift+G)) 是通过键盘打开终端链接的方式。该命令会打开一个快速选择器,其中包含终端视口中所有可用的链接。
选择 ⇧⌘G (Windows, Linux Ctrl+Shift+G) 键绑定是因为它与“转到编辑器中的符号”动作类似,但适用于终端。
转到最近目录 - Ctrl/Cmd+G
转到最近目录 (⌘G (Windows, Linux Ctrl+G)) 会打开一个快速选择器,其中包含由Shell 集成检测到的最近目录。它支持固定和模糊匹配。
选择此键盘绑定是因为 Ctrl+G 是一个使用频率相对较低的 Shell 键盘绑定。
向 Shell 发送 Ctrl+G - Ctrl+Alt+G
由于 Ctrl+G 现在用于“转到最近目录”,因此使用 Ctrl+Alt+G 是直接向 Shell 发送 Ctrl+G 的新方式。
运行最近命令 - Ctrl+Alt+R
运行最近命令 (⌃⌥R (Windows, Linux Ctrl+Alt+R)) 会打开一个快速选择器,其中包含最近运行的命令,其模型基于大多数 Shell 的反向索引搜索 (Ctrl+R),但以更易访问和更功能化的方式呈现。它支持固定和模糊匹配。
选择 ⌃⌥R (Windows, Linux Ctrl+Alt+R) 键绑定是因为它是 Ctrl+R 的替代行为,但该键绑定太重要,无法覆盖其默认行为。
辅助功能模式覆盖
由于反向索引搜索对屏幕阅读器来说不太方便,因此当辅助模式开启时,Ctrl+R 将触发运行最近命令,而 Ctrl+Alt+R 将向 shell 发送 Ctrl+R。
链接改进
此版本中终端的链接检测功能有许多改进
-
在某些情况下,包含空格的链接会被检测到
- 当整行都是链接时。
- Python 风格的堆栈跟踪链接:
File "<path>", line <line>
- 一些编译器错误:
<path>(<line>,<col>) : ...
- 文本中独立样式化的部分都独立检测,因此如果路径带下划线,即使有空格也应该被检测到。
-
包含
[
和]
字符的链接现在可以正常工作,它们甚至支持在以下困难的边缘情况下的检测 -
vscode://
协议链接现在已被检测到。 -
在 Windows 上,现在可以检测到
/mnt/
、\\wsl$\
和\\wsl.localhost\
链接。 -
OSC 超链接支持已在 v1.72 中添加,这些链接中常用的
file://
协议现在也受支持(例如ls --hyperlink
)。 -
terminal.integrated.enableFileLinks
设置现在提供了一个"notRemote"
选项,允许其仅在文件存在检查可能导致性能问题的远程环境中禁用。
大多数链接格式也始终支持以下行和列格式
<file>:<line>
<file>:<line>:<column>
<file> <line>
<file> <line>:<column>
<file>(<line>)
<file>(<line>,<column>)
<file>(<line>, <column>)
<file> (<line>)
<file> (<line>,<column>)
<file> (<line>, <column>)
- 单引号或无引号也适用于这些情况
"<file>",<line>
"<file>",<line>:<column>
"<file>", line <line>
"<file>", line <line>, col <column>
"<file>", line <line>, column <column>
"<file>":line <line>
"<file>":line <line>, col <column>
"<file>":line <line>, column <column>
"<file>": line <line>
"<file>": line <line>, col <column>
"<file>": line <line>, column <column>
"<file>" on line <line>
"<file>" on line <line>, col <column>
"<file>" on line <line>, column <column>
终端编辑器文件拖放支持
终端编辑器现在支持在按住 Shift 的同时拖放文件,将文件写入终端而不是打开编辑器。
“不安全”配置文件检测
由于安全漏洞,Windows 上 Cygwin Shell 的检测最近被移除。此版本中,我们以更安全的形式重新引入了此功能,并检测到更多 Shell 配置文件,包括 Cygwin、Cmder 和 MSYS2。为了缓解安全问题,在使用这些配置文件之前,必须通过“选择默认配置文件”命令进行配置。
选择后,将在添加到 settings.json
文件并像常规配置文件一样运行之前显示警告
如果计算机未被多个用户使用(例如在企业环境中),则可以安全地忽略此警告。
终端视图中的切换命令
一个长期以来的请求是向终端视图操作添加“清除终端”命令,但我们一直担心 UI 臃肿。得益于一项新的内部功能,我们有了默认隐藏但可以通过右键单击切换显示的溢出菜单中的新操作
Windows 上 Ctrl+C 释放选区
在 Windows 上,Ctrl+C 在复制选区和向 Shell 发送 SIGINT
之间共享,具体取决于是否存在选区。一个常见的烦恼是,如果您不小心创建了选区,Ctrl+C 可能不会发送 SIGINT
。为了缓解这种情况,Ctrl+C 复制选区现在也会清除选区,因此按两次 Ctrl+C 将可靠地发送 SIGINT
一次或两次。
添加终端 Tab 停止大小设置
新增设置 terminal.integrated.tabStopWidth
,用于配置终端的制表位宽度。当程序输出 \t
字符而不是在其配置中配置制表符大小时,这会很有用。
Powerline 三角形和斜线自定义字形
GPU 加速终端现在可以为三角形和斜线 Powerline 额外符号字形(U+E0B8-U+E0BF
)获得像素完美的自定义字形。这些字符在是单宽字符还是双宽字符方面是模糊的,并且因所用字体而异,因此我们选择将其呈现为单宽。
之前
之后
在“在活动终端中运行选定文本”中使用带括号的粘贴模式
“在活动终端中运行选定文本”命令现在将在支持的 Shell 中使用“带括号的粘贴模式”运行文本,因此多行选择将被视为单个输入,而不是多个命令。这使得运行实际脚本更加直观,错误更少。
之前
之后
Pwsh 预览反馈提供程序的快速修复
PowerShell Preview 最近实现了一个新的可插拔反馈提供程序系统,允许在命令失败时打印建议
终端现在从 [General]
和 [cmd-not-found]
反馈提供程序中拉取快速修复。快速修复对话框可以通过点击灯泡或通过 Ctrl/Cmd+.
打开。
源代码管理
新命令
Git 2.35 为 git stash
命令引入了一个新的 --staged
模式。这个新模式允许您轻松地只暂存已暂存的更改。如果您使用的 Git 版本支持此新模式,您可以通过新的“Git: 暂存已暂存”命令来利用它。
VS Code 已经支持使用“Git: 删除标签”命令删除本地标签。本次里程碑,我们启用了使用新的“Git: 删除远程标签”命令删除远程标签的功能。
父文件夹中的 Git 仓库
VS Code 使用 git rev-parse --show-toplevel
来确定 Git 仓库的根目录。在大多数情况下,Git 仓库的根目录位于工作区内,但也有一些情况,Git 仓库的根目录位于工作区或打开的文件(s)的父文件夹中。虽然在工作区或打开的文件的父文件夹中打开 Git 仓库对于高级用户来说是一个很棒的功能,但对于新用户来说可能会造成困惑。我们见过一些案例,这种困惑导致了丢弃这些 Git 仓库中的更改,从而造成数据丢失。
为了避免混淆并降低数据丢失的风险,从本次里程碑开始,VS Code 将在源代码管理视图中显示通知和新的欢迎视图,并且不会自动从工作区和打开的文件的父文件夹中打开 Git 仓库。
主题:Dark+ V2 与 MacOS Modern 产品图标
“打开仓库”按钮将打开一个快速选择器,其中包含在工作区或打开的文件(s)的父文件夹中发现的所有 Git 仓库的列表。从父文件夹中打开 Git 仓库的选择会被记住。
用户可以使用 git.openRepositoryInParentFolders
设置控制如何处理父文件夹中的 Git 仓库。希望恢复旧行为的用户可以将 git.openRepositoryInParentFolders
设置为 always
。
命令禁用
根据 Git 仓库的大小或各种 Git 钩子的存在,某些 Git 操作可能需要很长时间才能完成。我们过去曾发现,在前一个命令仍在进行时启动命令可能会导致意外结果(例如,在提交操作进行时丢弃文件上的更改)。
为防止这种情况发生,当以下操作正在进行时,我们禁用了大多数 Git 命令:Checkout
、Commit
、Push
和 Pull
。这意味着在这些操作运行时,大多数 Git 命令不会出现在命令面板中,并且会在源代码管理视图和状态栏中禁用。
用户界面改进
此里程碑中,我们优化了源代码管理用户界面的一些元素
- 源代码管理视图中“提交”和“发布分支”操作按钮的工具提示现在包含分支名称。
- “检出”状态栏项现在根据检出引用类型(分支、标签或提交)使用不同的图标。
- “检出”状态栏项现在在检出操作进行中时显示一个旋转进度图标。
笔记本
内核选择器改进
我们继续改进了 MRU(最近使用)内核选择器。通过将 notebook.kernelPicker.type
设置为 mru
可以启用它。未使用的内核将移至辅助选择器“选择另一个内核...”。当您安装了最新的Jupyter和Python扩展时,此选择器将按其来源(例如:Jupyter Kernel、Python Environment 等)对所有内核进行分组。
合并选定单元格
新增命令“合并选定单元格” (kb(notebook.cell.joinSelected
)`,用于将多个选定单元格合并为一个单元格。
输出回退渲染至支持的 mimetype
Jupyter Notebook 中的富文本输出(例如 IPyWidgets)仅在内核生命周期内可见。这意味着当笔记本关闭并重新打开时,输出不再可见。但是,在许多此类情况下,可以使用回退机制来渲染输出。例如,IPyWidget 在某些情况下(取决于所使用的 widget)可以作为静态图像或 HTML 内容进行渲染。
因此,打开包含 matplotlib widgets(或类似 widgets)的现有笔记本的用户现在可以无需重新执行代码即可查看输出。
新文档
有两篇新主题可以帮助您在 VS Code 中使用 Jupyter Notebooks。
- Web 上的 Jupyter Notebooks - 在 vscode.dev 或 GitHub Codespaces 中运行 Notebook。
- 管理 Jupyter 内核 - 了解如何将您的笔记本连接到各种 Jupyter 内核。
调试
JavaScript 调试
改进 Node.js 启动性能
用于 Node.js 调试的“断点预测器”已重写并改进,大幅提高了大型项目的速度。例如,调试 TypeScript 仓库中的单元测试时的启动时间开销减少了 62%,调试和启动 VS Code 仓库中的构建时的开销减少了 80%。
如果您遇到断点未命中等问题,请提交问题。您可以通过在 launch.json
中设置 "enableTurboSourcemaps": false
来禁用新行为,但随着我们信心的增加,此选项最终将被移除。
语言
JavaScript React 语言标签现已更名为 JavaScript JSX
JavaScript React
语言模式已更名为 JavaScript JSX
,以反映 JSX 语法不仅用于 React。TypeScript React
也已更名为 TypeScript JSX
。
请注意,仅更改了 UI 中显示的语言名称。内部语言 ID(javascriptreact
和 typescriptreact
)为了兼容性原因保持不变。
新的 Shellscript 语法
VS Code 现在使用来自 better-shell-syntax 的新语法进行 Shellscript 语法高亮。
扩展
VS Marketplace 扩展签名
从 2022 年 11 月开始,上传到 Visual Studio Marketplace 的每个扩展都由 VS Marketplace 进行代码签名。当用户通过 VS Code 的扩展视图安装已签名的扩展时,VS Code 会验证签名,从而证明该扩展确实来自 VS Marketplace,并且扩展包未被修改。如果签名验证失败,VS Code 将不会安装该扩展。
VS Marketplace 正在为所有现有扩展(包括自 11 月以来未更新的扩展)进行签名。此过程完成后,在几个月后,VS Code 将要求所有来自 VS Marketplace 的扩展都必须由 VS Marketplace 签名。此要求将保证来自 VS Marketplace 的每个包的完整性,从而提高我们扩展生态系统的整体安全性。
注意:扩展作者无需进行任何操作即可选择启用 Marketplace 签名。除了 Marketplace 签名之外,我们目前正在研究发布者签名。有关发布者签名的更多信息,请参阅讨论 #137。
从 CLI 固定扩展版本
当您从 CLI 安装特定版本的扩展时 (code --install-extension {publisher}.{name}@{version}
),它现在将固定在该版本。这意味着当您启用了自动更新时,扩展将不会自动更新。
同步固定扩展版本
设置同步现在将同步固定扩展版本。这意味着当您在一台机器上安装特定版本的扩展时,它将在您同步到的所有其他机器上固定到该版本。
对扩展的贡献
Python
从激活的终端启动 VS Code 时自动选择环境
如果用户通过已激活 conda 或虚拟环境的终端启动 VS Code,Python 扩展现在会检测到这一点,然后要么自动选择环境本身,要么询问用户是否希望将该环境作为其选定环境;具体取决于环境。
创建环境时选择 requirements 文件
使用“Python: 创建环境”命令创建虚拟环境时,Python 扩展现在会在工作区文件夹中查找 requirements 文件,并允许用户多选任意数量的 requirements 文件进行安装。
从 pyproject.toml 中选择可选依赖项
Python 扩展检测并加载 pyproject.toml
文件中 [project.optional-dependencies]
部分提供的可选依赖项。如果检测到工作区包含 pyproject.toml
以及任何选定的可选依赖项,则使用 pip 可编辑安装命令。
Pylance 自动缩进
当 Python 文件启用 editor.formatOnType
设置时,Pylance 将在您键入时自动缩进代码,让您更多地关注代码逻辑而不是格式化。
要试用此功能,请通过在用户 settings.json
文件中添加以下内容,为 Python 文件启用 formatOnType
"[python]": {
"editor.formatOnType": true,
},
实时预览
外部浏览器预览设置
实时预览扩展现在允许您在非默认浏览器中打开外部浏览器预览。使用 livePreview.customExternalBrowser
设置,您可以将外部预览设置为在以下浏览器中打开
- Microsoft Edge
- Google Chrome
- Mozilla Firefox
- 您的默认浏览器
服务器根目录设置
您现在可以将服务器的根路径设置为工作区中的子文件夹。例如,您可以将 livePreview.serverRoot
设置为 "src"
,让 Live Preview 从您工作区中的 src
文件夹提供文件。
ESLint
ESLint 扩展已更新到版本 2.4.0。主要新功能有:
-
支持新的实验性平面配置文件。您需要在 VS Code 中使用
eslint.experimental.useFlatConfig
设置单独启用支持。需要 ESLint 8.21 或更高版本。 -
ESLint 状态指示器已移至 VS Code 的语言状态区域。因此,
eslint.alwaysShowStatus
设置已被移除。请改用 VS Code 的固定功能。语言状态项现在将通知您在保存时计算代码修复期间验证时间过长和 ESLint 运行时间过长。可用时间预算(以毫秒为单位)可以通过
eslint.timeBudget.onValidation
和eslint.timeBudget.onFixes
这两个设置进行控制。 -
可以使用新的设置
eslint.problems.shortenToSingleLine
将长问题波浪线缩短为单行。
GitHub 拉取请求和问题
GitHub 拉取请求和问题扩展取得了更多进展,该扩展允许您处理、创建和管理拉取请求和问题。亮点包括:
- 支持建议和接受更改。
- 评论中的 GitHub 句柄现在已链接化。
- 在创建 PR 时可以添加标签。
- 实验性设置
githubPullRequests.experimental.quickDiff
将在编辑器侧边栏中显示已检出 PR 中已更改行的快速差异视图。
请查看扩展的0.58.0 版本更新日志以了解其他亮点。
GitHub Copilot
GitHub Copilot 扩展是一个由 AI 驱动的代码补全工具,可帮助您更快、更智能地编写代码。您可以在 VS Code 中使用 Copilot 扩展来生成代码,或从其生成的代码中学习。
GitHub Copilot 通过行内建议 UI 集成到 VS Code 编辑器中,让您可以查看各种建议并轻松接受生成代码的全部或部分。
GitHub Copilot 现已面向企业普遍可用,具备许可证管理、组织范围的策略控制和隐私保护等功能。您可以在GitHub Copilot for Business 公告中了解更多信息。
要开始使用,您可以在GitHub Copilot 网站上注册免费试用。
我们还在 VS Code 文档中添加了一个新的VS Code 中的 GitHub Copilot 主题,这将帮助您开始使用 Copilot。
远程开发
远程开发扩展允许您将容器、远程机器或 适用于 Linux 的 Windows 子系统 (WSL) 用作功能齐全的开发环境。此版本亮点包括:
- Dev Container 支持多个
devcontainers.json
文件。 - Docker 凭证转发。
- X11 和 Wayland 转发
您可以在远程开发发布说明中了解新的扩展功能和错误修复。
远程隧道
防止休眠
远程隧道现在可以防止 Windows、macOS 和基于 systemd 的 Linux 系统进入休眠状态。如果您离开桌面进行远程工作并希望确保隧道保持可访问,这会很有用。要使用此功能:
- 从 VS Code UI 启用远程隧道访问时,将设置
remote.tunnels.access.preventSleep
更新为true
。 - 在 CLI 上使用
code tunnel
时,传入--no-sleep
标志。
可靠性改进
远程隧道中一些与连接相关的问题已得到修复,这应该会提高可靠性。
继续工作
“继续工作”功能支持在本地窗口中启动 Git 仓库,并在像 GitHub Codespace 这样的远程窗口中继续。如果您所在的分支尚未发布到远程,当您选择在不同的开发环境中继续工作时,系统将自动提示您发布当前分支,以便您可以在其他地方访问完整的支上下文。
此外,当您在远程窗口中的 Git 仓库上时,您现在可以使用“在新的本地克隆中继续工作”命令在 VS Code 桌面中继续在新的本地 Git 克隆中工作。
最后,所有在本地、远程或 Web 窗口中继续工作的选项现在都方便地显示在远程指示器中。这些选项也已在命令面板中可用。
预览功能
Dark+ V2 和 Light+ V2 实验性主题
两个新的颜色主题,Dark+ V2 和 Light+ V2,现已可用。这些主题是现有 Dark+ 和 Light+ 主题的演变,旨在提高可访问性,并使 VS Code 比以往任何时候都更好看!这些主题仍被标记为实验性,我们正在寻求早期反馈。
您可以在颜色主题选择器(首选项:颜色主题 ⌘K ⌘T (Windows, Linux Ctrl+K Ctrl+T))中找到列为“Light+ V2 (实验性)”和“Dark+ V2 (实验性)”的新主题。
TypeScript 5.0 支持
此更新包含对即将发布的 TypeScript 5.0 版本的支持。有关 TypeScript 团队目前正在进行的工作的更多详细信息,请参阅TypeScript 5.0 迭代计划。一些编辑器工具亮点:
- 新的
switch
和case
补全功能可帮助您更快地填写switch
语句的两个部分。 - 致力于在 github.dev 和 vscode.dev 上启用项目范围的 IntelliSense。
要开始使用 TypeScript 5.0 每夜构建版本,请安装 TypeScript Nightly 扩展。
命令面板中的“常用”部分
在此里程碑中,我们为命令面板添加了一个新的“常用”部分。此部分的目的是帮助新用户更好地了解命令面板的用途和功能。
主题:Panda Theme (在 vscode.dev 上预览)
此部分将显示在“最近使用”部分下方,以免破坏肌肉记忆;随着您运行的命令越来越多,对 VS Code 越来越熟悉,此部分要么消失(因为“常用”命令已移至“最近使用”),要么此部分位于视线之外。
主题:Panda Theme (在 vscode.dev 上预览)
目前,我们已将此新体验置于 workbench.commandPalette.experimental.suggestCommands
设置之后,但我们计划在不久的将来使其成为默认行为。请告诉我们您的想法!
扩展开发
评论线程状态
CommentThread
state
API 已最终确定。此 API 控制评论是显示为已解决还是未解决,并可能影响“评论”视图中的筛选。您可以在问题 #127473 中了解更多关于如何使用此 API 的信息。
忽略要同步的设置
您现在可以在注册设置时使用 ignoreSync
属性,默认情况下将设置从“设置同步”中隐藏。这对于不打算在机器之间同步的设置很有用。
遥测
新的 TelemetryLogger
API 已最终确定。此 API 旨在使扩展作者更容易使用遥测,并对最终用户更安全。该 API 支持内置的秘密清理、遥测输出通道、错误处理程序和自动遥测级别管理等功能。这应能带来更具凝聚力的遥测体验,并保证符合我们的要求。
建议的 API
每个里程碑都会带来新的建议 API,扩展作者可以尝试。一如既往,我们期待您的反馈。以下是尝试建议 API 的步骤:
- 找到您想要尝试的提案,并将其名称添加到
package.json#enabledApiProposals
中。 - 使用最新的 vscode-dts 并运行
vscode-dts dev
。它会将相应的d.ts
文件下载到您的工作区。 - 您现在可以针对该提案进行编程。
您无法发布使用建议 API 的扩展。在下一个版本中可能会有重大更改,我们绝不希望破坏现有扩展。
让笔记本渲染器回退到不同的 mimetype
有时,在渲染内容时,笔记本渲染器可能会发现它无法正确渲染项目。例如,渲染器可能要求内核处于特定状态。
以前在这种情况中,渲染器唯一的选择是渲染错误消息。我们添加了一个新的提议 API,它允许渲染器抛出一个特殊命名的错误,这会导致 VS Code 静默地回退到渲染存储在笔记本输出项上的其他数据。例如,交互式图表渲染器可以抛出此错误,以使 VS Code 回退并渲染当前输出项上存储的图像数据。
要触发此回退,请在 renderOutputItem
中抛出名称为 vscode.fallbackToNextRenderer
的错误
throw new class extends Error {
override name = 'vscode.fallbackToNextRenderer';
}();
此特殊错误仅适用于在某些情况下预期会失败的渲染情况。如果您的渲染器遇到意外错误,它应继续显示错误消息。
快速差异
快速差异,即编辑器中已添加、更改和删除行上显示的行槽装饰,目前仅供 SCM 提供程序使用。建议的快速差异 API 允许在 SCM 提供程序之外使用快速差异。以下示例来自 GitHub Pull Request 扩展,该扩展使用快速差异 API 显示 PR 中更改行的快速差异。
vscode.window.registerQuickDiffProvider(
{ scheme: 'file' },
{
provideOriginalResource: (uri: vscode.Uri) => {
const changeNode = this.reviewModel.localFileChanges.find(
changeNode => changeNode.changeModel.filePath.toString() === uri.toString()
);
if (changeNode) {
return changeNode.changeModel.parentFilePath;
}
}
},
'GitHub Pull Request',
this.repository.rootUri
);
完整的提案位于 quickDiffProvider.d.ts。
持续测试运行
持续测试运行允许测试扩展指示它们能够在发生更改时监视和重新运行测试。支持此 API 的关键是在测试运行配置文件中指示支持...
const profile = controller.createRunProfile('Run', TestRunProfileKind.Run, runHandler);
+profile.supportsContinuousRun = true;
然后在 runHandler 中进行检查
const runHandler = (request: TestRunRequest, token: CancellationToken) => {
+ if (request.continuous) {
+ return watchForFileChangesThenRunTests(request, token);
+ }
}
完整的提案位于 testContinuousRun.d.ts。
工程
扩展主机实用进程
扩展主机所需的实用进程使用(用于进程沙盒)现在默认启用。仍然有一个设置 (extensions.experimental.useUtilityProcess
),我们很快就会将其移除。
通过命令行进行性能测试
我们引入了以下 Node.js 模块,用于从命令行运行一组性能测试。
vscode-bisect - 此模块有助于我们快速测量性能退步。运行 npx vscode-bisect --help
以了解如何操作此工具。
vscode-perf - 此模块帮助我们测量 VS Code 的性能。npx vscode-perf --help
描述了如何操作此工具。
GB18030 认证
VS Code 现已通过 GB18030 认证——这意味着中国政府内的认证委员会已确认 VS Code 可以正确表示所有中文字符。测试涵盖了所有内置使用场景。随着 VS Code 获得认证,核心 Visual Studio 系列(包括 Visual Studio 和 Visual Studio for Mac)均已通过 GB18030 认证。
迁移到 ESM
我们已踏上将代码库迁移到 ESM 的征程。VS Code 项目早于原生模块 (ESM),我们暂时使用了异步模块系统 (AMD)。AMD 为我们服务良好,但现在是时候向前迈进了。我们已经开始将代码库迁移到 ESM,我们正在取得良好进展,并希望在未来几个月内完成这项工作。
macOS 10.11 和 10.12 的生命周期结束警告
VS Code 桌面将在接下来的几个里程碑中更新到Electron 22。随着 Electron 22 的更新,VS Code 桌面将不再在 OS X El Capitan 和 macOS Sierra 上运行。在此里程碑中,我们为这些受影响平台的用户添加了弃用通知,以帮助他们准备迁移。如果您是上述操作系统的用户,请查阅我们的常见问题解答以获取更多信息。
改进系统和应用程序语言变量的使用
在之前的版本中,我们开始将应用程序语言传递给 Electron,以便它可以正确地布局一些组件,例如窗口控件覆盖 (WCO)。同时,语言推荐器依赖于系统语言,但 app.getLocale()
开始获取应用程序语言而不是系统语言,因此我们使用了一个较新的 app.getPreferredSystemLanguages()
Electron API 来检索用于语言推荐器的系统语言。结果,发生了一个回归,导致扩展在扩展视图中无法渲染,因为新的 API 返回了一些 toLocaleString()
无法解析的值。
立即的解决方案(我们为恢复版本推出了该方案)是恢复使用 app.getLocale()
并暂时中断语言推荐功能,但事实证明,代码库的许多区域也应该使用应用程序语言变量而不是系统语言变量。
此版本将系统语言的许多用法替换为应用程序语言。因此,日期现在应该以更符合应用程序语言而非系统语言的格式进行本地化。
显著修复
- 99878 在 macOS 上,使用 environmentVariableCollection 预置 PATH 环境变量不起作用
- 153786 有一个命令可以打开差异编辑器的任意一侧
- 165123 允许打开带有两个未命名侧的差异编辑器
- 167004 输出:显示输出通道 一个用于显示输出通道的命令
- 167528 扩展输出通道的日志级别在窗口重新加载后仍然存在
感谢
最后但同样重要的是,衷心感谢 VS Code 的贡献者。
问题追踪
对我们问题追踪的贡献
- @gjsjohnmurray (John Murray)
- @IllusionMH (Andrii Dieiev)
- @ArturoDent (ArturoDent)
- @yume-chan (Simon Chan)
拉取请求
对 vscode
的贡献
- @a-stewart (Anthony Stewart): 在 browser.ts 中使用 matchMedia 调用一致地指定窗口 PR #164020
- @Aaaaash (大表哥): 修复
standaloneTheme.defines
始终返回 false。 PR #169221 - @andschwa (Andy Jordan): 修复 PowerShell 5.1 的 Shell 集成 PR #170516
- @antonioprudenzano (Antonio Prudenzano): Feat/155294 PR #168513
- @babakks (Babak K. Shandiz)
- 在 markdown 语法标记中包含波浪号 (~) PR #146417
- 🖊 在提交按钮弹出窗口中包含分支名称 PR #167827
- 添加无选区监视 PR #171449
- @Balastrong (Leonardo Montini): 145458 列表:支持按页滚动 PR #145788
- @chiefmikey (Mikl Wolfe)
- 移除 repository.ts 默认参数类型 PR #155908
- 更新 git config.followTagsWhenSync 定义 PR #155914
- @chouzz (Chouzz): 修复调用层次结构和类型层次结构 API 的不正确描述 PR #167718
- @d1y (源来氏佐田): feat: 截屏模式移动缩放 PR #156084
- @davidwengier (David Wengier): 更新 Razor 仓库 PR #171560
- @dtivel (Damon Tivel)
- 扩展:签名验证期间的 UnknownError 警告而非失败 PR #169777
- 如果无法验证扩展签名,则不阻止 PR #172576
- @fadeevab (Alexander Fadeev): Makefile 测试
else ifeq|ifneq|...
语法 PR #170888 - @giannisp (Ioannis Poulakas): 改进搜索输入布局 PR #165989
- @gjsjohnmurray (John Murray)
- 为新的列表/树搜索/筛选小部件添加历史记录 (#_155578) PR #159188
- 为树查找小部件添加“模糊匹配”开关 (#_116286) PR #164376
- 防止隐藏未解决的树分支 PR #167047
- @gpoussel (Guillaume Poussel): 添加命令以删除远程标签(修复 #104845) PR #134327
- @HKalbasi: 修复行内提示位置链接问题 PR #167886
- @hughlilly (Hugh Lilly): 校对:“Double-clicking” -> “Double-clicking” PR #166758
- @jakebailey (Jake Bailey): 在 TS 用户首选项中设置 disableLineTextInReferences=true PR #171376
- @jasonwilliams (Jason Williams): 允许将差异编辑器的任意一侧作为编辑器打开(修复 #153786) PR #165765
- @jeanp413 (Jean Pierre)
- 修复粘贴到快速大纲不显示结果的问题 PR #166835
- 修复退出后编辑器区域终端未恢复的问题 PR #168887
- 修复重新加载后恢复的终端/任务忽略 confirmOnKill 和 confirmOnExit 设置的问题 PR #168922
- 修复 createTerminal 不在第一个编辑器组创建终端的问题 PR #169050
- @joshuaobrien: 添加 git stash staged only 命令 PR #165649
- @laurentlb (Laurent Le Brun): 命令持续时间:遥测使用更高精度 PR #167624
- @maIIady (Ilya Golovin): 修复:使 git 命令通过键盘工作 PR #159113
- @markw65: 修复不同文件夹中同名任务不自动启动的问题 PR #168742
- @MarkZuber (Mark Zuber): 为网络协议添加高延迟测量工具 PR #168668
- @meskill: 修复:nushell 集成 PR #169861
- @mkhl (Martin Kühl): 通过
XDG_DATA_DIRS
公开 fish 集成配置 PR #168211 - @MonadChains (MonadChains)
- 问题 163528/创建编辑断点命令 PR #163734
- 至少启动一次调试后启用断点视图 PR #169077
- @mroch (Marshall Roch): 修复 anyScore firstMatchCanBeWeak PR #168266
- @mueheg (Google Henrik): 在选择范围之前不要选择输入框的全部内容,修复 #167266。 PR #167274
- @N1kO23: 添加了
${rootNameShort}
格式化 PR #165744 - @ohah (ohah): 截屏输入法 bug 修复 (#_165248) PR #165249
- @ookami-kb (Kirill Bubochkin): 更新 shellIntegration.fish 以修复通信 cwd 时出错的问题 PR #168452
- @PEZ (Peter Strömberg): 为状态栏项目启用等宽数字 PR #167310
- @pokey (Pokey Rule): 修复代码片段选择转义的 bug PR #169287
- @probablykasper (Kasper): 添加
terminal.integrated.tabStopWidth
选项 PR #170733 - @pzhlkj6612 (Mozi): 终端标签页:重命名时禁用拖拽和点击 PR #166821
- @r3m0t (Tomer Chachamu): 修复扩展启动慢导致 webview 消失的问题 (#_168516) PR #168569
- @rezasoumi (RezCoder): 问题 163803/ 先选择一个引用,然后在 create-branch-from... 中选择一个名称 PR #170908
- @rwe (Robert Estelle): shellIntegration-bash.sh: 精确保留 DEBUG trap 表达式 PR #165581
- @samdenty (Sam Denty): 修复 IExtensionRecommendationReson 拼写错误 PR #163889
- @Sean1708 (Sean Marshallsay): 引入 VSCODE_RESOLVING_ENVIRONMENT 环境变量。 PR #168436
- @ssigwart (Stephen Sigwart)
- 添加和移除组或切换侧边栏时保留最大化组大小 PR #137962
- 修复粘贴时移除缩进的问题 PR #167687
- 添加驼峰式转换 PR #169512
- @ste42 (Steven Tam): 添加新的未命名差异命令 PR #168533
- @sumneko (最萌小汐): 更新 Lua 语法 PR #167692
- @weartist (Han)
- 修复设置以禁用差异视图中“下一次更改”的循环 #163331 PR #164225
- 为 #165169 适配 CSS PR #167030
- 支持进程资源管理器记住其位置和尺寸 PR #169090
- 在出现同名代码片段时添加代码片段来源 PR #169119
- 将 applicationStorageMainService 替换为 stateMainService PR #169365
- @yiliang114 (易良): 修复:拼写错误 PR #158431
- @zardoy (Vitaly): [typescript] 修复成员补全中潜在的
[object Object]
问题 PR #171127
对 vscode-css-languageservice
的贡献
- @romainmenke (Romain Menke): 新的 CSS 单位 PR #324
对 vscode-hexeditor
的贡献
- @brabli (Bradley): 在数据检查器中添加当前字节的八进制表示 PR #410
对 vscode-json-languageservice
的贡献
- @rahulbanerjee26 (Rahul Banerjee): 检查 "not" 规则的 schema 中
errorMessage
属性 PR #164
对 vscode-languageserver-node
的贡献
- @wkillerud (William Killerud): 为 onPrepareRename 添加 defaultBehavior 响应 PR #1161
对 vscode-pull-request-github
的贡献
- @eamodio (Eric Amodio): 更新 TypeScript(发布 4.2 版)和 Octokit(以获取修复的类型),以及其他一些小更新 PR #2525
- @sravan1946 (sravan): 从 readme 中移除不可用的徽章 PR #4393
- @Thomas1664
对 debug-adapter-protocol
的贡献
- @mfussenegger (Mathias Fußenegger): 阐明帧上缺少 canRestart 意味着 true PR #365
对 monaco-editor
的贡献
- @jonatanklosko (Jonatan Kłosko): 更新 Elixir 分词器 PR #3453
- @rcjsuen (Remy Suen): 修复颜色提供者的列 PR #3348