2019 年 1 月 (版本 1.31)
1.31.1 更新:本次更新解决了这些 问题。
下载:Windows:x64 | Mac:Intel | Linux 64 位:deb rpm tarball | 32 位:deb rpm tarball
欢迎使用 Visual Studio Code 2019 年 1 月版。此版本中有许多重要更新,希望您会喜欢,其中一些主要亮点包括:
- 安装扩展无需重新加载 - 安装新扩展时不会中断。
- 树形 UI 改进 - 改进了资源管理器导航和过滤,支持水平滚动。
- 主菜单更新 - 重新设计了 Go 操作菜单,编辑菜单增加了剪切命令。
- 多行问题输出 - 在“问题”面板中查看完整的多行问题详细信息。
- 查找所有引用历史记录 - 快速重新运行以前的引用搜索。
- HTML、CSS 和 JSON 的语义选择 - 根据语言语义展开/收缩选择。
- 集成终端重排支持 - 终端文本会随面板宽度变化自动重排。
- 基于命令的用户输入变量 - 任务和调试配置的自定义用户输入。
- 更新的扩展 API 文档 - 完全重写并附带扩展指南。
如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新页面。
您还可以查看 Cloud Developer Advocate Brian Clark 制作的 1.31 版本 亮点视频。
发布说明按以下与 VS Code 重点领域相关的部分进行排列。以下是一些进一步的更新
- 工作台 - Zen 模式隐藏行号,新的截屏模式显示按键。
- 编辑器 - 智能选择改进,调整引用 CodeLens 位置。
- 集成终端 - Windows 上的 ConPTY 支持,查找改进。
- 扩展创作 - 扩展更改事件,在浏览器中打开资源操作。
Insiders:想尽快看到新功能吗?您可以下载每夜更新的 Insiders 构建版本,并第一时间尝试最新的更新。有关最新的 Visual Studio Code 新闻、更新和内容,请在 Twitter 上关注我们 @code!
扩展
安装无需重新加载
能够在不强制重新加载 (重启) VS Code 的情况下安装扩展是投票最多的功能请求之一,我们在本次发布中为您带来了此功能。安装或启用扩展时不再需要重新加载 VS Code。
在下面的示例中,用户在打开 .vue
文件后遵循建议安装 Vetur 扩展。请注意,Vetur 扩展提供的语言功能(例如语法着色、诊断错误)在安装推荐的扩展后立即可用。
如果扩展未激活,则卸载或禁用扩展时也无需重新加载。
注意:有些扩展需要重新加载,因为它们依赖外部贡献(对其他扩展的扩展点做出贡献)。这需要外部贡献点所有者通过监听 extensions.onDidChange
事件来采纳。
工作台
新的树形小部件
我们已将小部件游戏提升到一个新的水平:创建了一个新的树形小部件来解决性能问题,并使我们能够在多个工作台区域提供更多功能。新的树形小部件是通过在我们高性能列表小部件的基础上进行组合创建的。我们打算就这项工程工作和性能改进撰写一篇单独的博客文章。目前,我们将重点关注功能。
注意:新树已在文件资源管理器、所有调试树、搜索和“查看引用”中采用。下面描述的功能适用于大多数这些 UI 区域,除非我们明确禁用。
改进的键盘导航
现在树中有三种不同类型的键盘导航:simple
、highlight
和 filter
。在 highlight
和 filter
模式下,在树中键入时,树的顶部会显示一个小部件(控件),表明您现在正在导航树。
此小部件还可以用于在 highlight
和 filter
模式之间切换。如果您希望使用键盘快捷键在模式之间切换,可以配置一个键盘绑定来执行 list.toggleFilterOnType
命令。工作台 > 列表:键盘导航 (workbench.list.keyboardNavigation
) 设置设置了默认模式,包括 simple
模式,在该模式下,键入树元素的几个首字母只会聚焦该元素。
为列表/树操作设置了单字母键盘绑定的用户仍然可以使用此功能,方法是利用 listAutomaticKeyboardNavigation
上下文键。例如,VIM 扩展将此上下文键设置为 false
以禁用自动键盘导航,并为 list.toggleKeyboardNavigation
命令添加了键盘绑定 /
,因此用户只需键入 /
即可导航树。在 VSCodeVIM 拉取请求 中了解更多信息。
主题作者可以使用以下新主题键自定义小部件的颜色:
listFilterWidget.background
listFilterWidget.outline
listFilterWidget.noMatchesOutline
注意:这些键盘导航模式目前仅适用于已解析的树节点。例如,在文件资源管理器中,如果从未展开文件夹,树将不会查找其子级。我们正在考虑多种选项来改善此体验。
分层全选
在树中按下 Ctrl+A
(macOS 上为 Cmd+A
)现在将以分层方式展开树的选择。
可自定义缩进
您现在可以使用 工作台 > 树:缩进 (workbench.tree.indent
) 设置来自定义工作台中所有树的节点缩进。
全部展开/折叠
在展开/折叠树节点时按住 Alt
键现在将递归工作。请注意,递归展开仅适用于树中先前显示过的节点。例如,文件资源管理器不会自动展开用户以前从未展开过的文件夹。
水平滚动
工作台 > 树:水平滚动 (workbench.tree.horizontalScrolling
) 设置现在可以在更多树和列表上启用水平滚动,即资源管理器、搜索、SCM、调试等。
问题面板
多行消息
“问题”面板现在以单独的行显示多行诊断消息。下面的示例显示了 TypeScript 的多行错误消息现在如何呈现。
您还可以使用折叠/展开按钮或 问题:在单行中显示消息 和 问题:在多行中显示消息 命令来切换显示或隐藏完整消息。
使用键盘快捷键触发代码操作
您现在可以使用与快速修复命令相同的默认键盘快捷键 ⌘. (Windows、Linux Ctrl+.) 从“问题”面板触发代码操作。
改进的 Go 菜单
我们为 Go 菜单添加了更多导航操作,使其更易于发现。
资源管理器上下文菜单中的剪切命令
根据普遍请求,我们已将剪切命令添加到资源管理器上下文菜单中。
快速滚动
按下 Alt
键可在编辑器和资源管理器中启用快速滚动。默认情况下,快速滚动使用 5 倍速度乘数,但您可以通过 编辑器:快速滚动灵敏度 (editor.fastScrollSensitivity
) 设置控制乘数。
Zen 模式隐藏行号
现在打开 Zen 模式也会隐藏编辑器行号。此行为可以通过 zenMode.hideLineNumbers
设置控制。
在 Linux 中添加了带自定义菜单的键盘导航
我们的自定义菜单现在支持使用 Page Up/Down
和 Home/End
键快速跳转到菜单的开头或结尾。
在 Windows/Linux 中双击应用程序图标关闭
由于技术权衡,默认情况下,Windows 和 Linux 上的自定义标题栏会移除双击应用程序图标关闭窗口的功能。可以通过启用设置 window.doubleClickIconToClose
来恢复此功能,但缺点是您将无法再从该位置拖动窗口或在 Windows 上获取系统上下文菜单。
编辑器选项卡关闭顺序
新设置 workbench.editor.focusRecentEditorAfterClose
允许您更改编辑器选项卡关闭的顺序。默认情况下,选项卡将按最近使用 (MRU) 顺序关闭。更改此设置允许从右到左关闭选项卡。
新标题变量
有三个新变量可以在 window.title
设置中使用:
${activeFolderShort}
:文件所在文件夹的名称。${activeFolderMedium}
:文件所在文件夹的路径,相对于工作区文件夹。${activeFolderLong}
:文件所在文件夹的完整路径。
输出面板
“输出”面板中的智能滚动行为现在效率更高。当您单击“输出”面板中的任意位置时,滚动会锁定,当您单击最后一行时,滚动会解锁。
截屏模式
VS Code 中新增了 截屏模式,它会突出显示光标位置和按键。截屏模式(开发人员:切换截屏模式)可用于演示目的。
编辑器
智能选择
我们已努力改进“选择”菜单中的展开选择和收缩选择的实现。我们正在添加一个 API,以便语言服务器可以根据其语义知识指定选择步骤。此外,我们还改进了默认实现。
敬请关注,随着智能选择的改进,更多功能即将推出。使用 smart-select
标签可查看我们正在进行的工作。
引用历史记录
现在,“引用”视图中有一个 引用:显示历史记录 命令。它会显示带有以前搜索结果的快速选择,允许快速重新运行以前的搜索。
引用 CodeLens
选择引用 CodeLens 时,会打开一个 Peek 编辑器。现在可以使用 references.preferredLocation
设置控制此功能。其选项是 peek
和 view
,后者在新视图中显示引用。
代码片段描述
以前,在编写具有长描述的代码片段时,您被迫编写一个长字符串。不支持像 body
那样使用数组。现在,这种情况已改变,可以使用字符串数组编写长描述。
{
"prefix": "happy",
"body": "#Happy Coding!",
"description": ["First Line", "Second Line", "Third Line"]
}
删除了旧版搜索模式
20 个版本前,我们开始在 VS Code 中使用 ripgrep 进行搜索。我们基于旧 Node.js 的搜索实现仍然可以通过 search.useLegacySearch
设置使用。但正如 Marie Kondo 所说,我们必须整理不再让我们感到快乐的事物。如果您一直在使用正则表达式功能,例如反向引用或前瞻,请确保打开 search.usePCRE2
设置。
使用简单文本编辑器将设置编辑为 JSON
类似地,既然我们已经有了几个版本的设置 UI,我们正在考虑简化 JSON 设置编辑体验。如果您通过打开 settings.json
文件或单击设置 UI 中的 {}
按钮或调用 首选项:打开用户设置 (JSON) 命令来将设置编辑为 JSON,那么您将获得一个简单的 JSON 编辑器,而不是我们以前的拆分 JSON 编辑器。您仍然可以使用 首选项:打开默认设置 (JSON) 命令查看默认设置列表。
如果您确实怀念左侧带有默认设置的拆分 JSON 编辑器,可以通过启用 workbench.settings.useSplitJSON
设置来恢复它。请注意,如果您更喜欢以 JSON 形式编辑设置,则始终可以这样做。
扩展的网络代理支持
Http: 代理支持 (http.proxySupport
) 设置现在默认启用所有扩展的网络代理支持。
语言
TypeScript 3.3
我们现在提供 TypeScript 3.3.1。此 TypeScript 更新带来了一些重要的错误修复和完善。
移除 markdown.previewFrontMatter 设置
markdown.previewFrontMatter
设置已移除。Markdown 预览现在总是隐藏 YAML frontmatter(这是 markdown.previewFrontMatter
的默认设置)。
Markdown 扩展,例如 Markdown yaml Preamble 和 GitHub Markdown Preview,在预览中将 frontmatter 渲染为表格。
语义选择
HTML、CSS/LESS/SCSS 和 JSON 现在支持语义选择。
集成终端
重排支持
当终端水平调整大小时,它现在将换行和取消换行。
Windows 上的 ConPTY 支持
通过 Windows ConPTY API 管理终端进程现在作为 Windows Insider 快速通道(内部版本号 18309+)中的可选功能提供。
{
"terminal.integrated.windowsEnableConpty": true
}
这将使用 Windows Console 团队提供的 ConPTY 系统作为终端的后端。启用此功能应该可以修复 Windows 终端的许多问题,特别是在颜色支持、交互式应用程序和原生支持 VT 序列的 Shell 方面。
以下是 WSL 终端中 256 ANSI 颜色支持的改进前后对比:
用于链接的当前工作目录
在 Linux 和 macOS 上,终端现在将根据当前工作目录而不是终端的初始目录解析链接。
终端查找改进
终端查找现在支持增量“边键入边查找”搜索,以及在单行中查找多个术语的功能。
commandsToSkipShell 设置的改进
以前,terminal.integrated.commandsToSkipShell
设置是一个列表,其中包含所有将跳过终端评估而由 VS Code 处理的命令。这很麻烦,因为您需要在设置文件中列出 100 多个命令才能更改它。现在,它已更改为增量和删除列表,因此您只需包含对默认列表的更改。
{
"terminal.integrated.commandsToSkipShell": [
// Make ctrl+n open a new file when the terminal is focused
"workbench.action.files.newUntitledFile",
// Send ctrl+e to the terminal
"-workbench.action.quickOpen"
]
}
新的缓冲区实现已启用
v1.29 中引入的基于 TypedArray/ArrayBuffer 的终端缓冲区现已启用,旧实现已移除。这应该会大大提高终端的吞吐量,并显著减少其内存占用。
调试和任务
自定义命令用户输入变量
上一个里程碑中引入的输入变量是一种强大的机制,用于在任务或调试配置中请求用户输入。最初,我们提供了 promptString
和 pickString
输入变量。
在这个里程碑中,我们引入了一种新型的输入变量 command
,它在插值输入变量时运行任意命令。由于命令可以由扩展提供,因此现在可以通过新的实现来扩展用户输入变量。
以下示例展示了如何在调试配置中使用类型为 command
的用户输入变量,该变量允许用户从特定文件夹中找到的所有测试用例列表中选择一个测试用例。假设某个扩展提供了一个 extension.mochaSupport.testPicker
命令,该命令可在可配置位置查找所有测试用例并显示选择器 UI 以选择其中一个。
{
"configurations": [
{
"type": "node",
"request": "launch",
"name": "Launch Test",
"program": "${workspaceFolder}/${input:pickTest}"
}
],
"inputs": [
{
"id": "pickTest",
"type": "command",
"command": "extension.mochaSupport.testPicker",
"args": {
"testFolder": "${workspaceFolder}/tests"
}
}
]
}
任务输出支持拆分终端
您现在可以配置任务以在拆分终端面板中显示输出,而不是创建新终端。任务配置可以在 presentation
部分中使用 group
属性来定义任务输出应显示的位置。
如果您同时运行以下两个任务,它们将显示在拆分终端中,以便您可以同时看到它们。
{
"version": "2.0.0",
"tasks": [
{
"label": "Task One",
"type": "shell",
"command": "echo One && sleep 5000",
"problemMatcher": [],
"presentation": {
"group": "groupA"
}
},
{
"label": "Task Two",
"type": "shell",
"command": "echo Two && sleep 5000",
"problemMatcher": [],
"presentation": {
"group": "groupA"
}
}
]
}
预览功能
预览功能尚未准备好发布,但已足够实用。我们欢迎您在这些功能开发期间提供早期反馈。
工作台的网格布局
工作台布局正在重新设计,以使用编辑器本身使用的相同网格布局。这项工作不仅可以从长远来看简化维护工作台布局的工程工作,还可以帮助我们开启新的体验。
在这个里程碑中,我们正在推出一种这样的体验,以展示使用新网格布局更容易实现的功能,即切换编辑器区域。启用实验性网格布局("workbench.useExperimentalGridLayout": true
)后,有一个新的命令切换编辑器区域,它可以隐藏代码编辑器。这允许您创建一个 VS Code 终端面板,该面板占据完整的编辑器区域,如下图所示。
如果您使用 code file.txt
从终端打开文件,它仍然会像您期望的那样弹出一个编辑器。此功能仍在开发中,并且存在已知问题,但我们鼓励您试用并提交问题。您可以通过 此查询 随时了解有关此工作的问题。
HTML 和 CSS 自定义数据支持
由于此功能处于预览阶段,因此设置、贡献点和数据格式可能会发生变化。
如今,前端开发人员通常使用 HTML/CSS 的超集进行编码:
- Web Components 允许自定义 HTML 元素,例如
<my-button type="alert"></my-button>
。 - PostCSS 允许自定义 CSS 属性,例如
size
,以及尚未标准化的 CSS 功能,例如:any-link
。 - 各种框架甚至在源 HTML/CSS 中提供了更大的灵活性。
在本次迭代中,我们改进了 1.30 中引入的 HTML 自定义数据支持,并添加了 CSS 自定义数据支持。
- 使用
html.experimental.customData
或css.experimental.customData
加载自定义数据。(html.experimental.custom.tags
和html.experimental.custom.attributes
已移除。) - 或者,将 JSON 与
contributes.html.experimental.customData
或contributes.css.experimental.customData
打包到扩展中。 - 最后,如果您正在编写使用 vscode-html-languageservice 或 vscode-css-languageservice 的语言服务器,您可以使用自定义数据创建语言服务。
自定义数据增强了 VS Code 对 HTML/CSS 的理解。例如,通过这些 HTML/CSS JSON 贡献,VS Code 可以为自定义 HTML 标签/属性和 CSS 属性/伪类提供完成和悬停。
{
"version": 1,
"tags": [
{
"name": "my-button",
"description": "My button",
"attributes": [
{
"name": "type",
"description": "My button type",
"values": [{ "name": "alert" }]
}
]
}
]
}
{
"version": 1,
"properties": [
{
"name": "my-size",
"description": "Compiles down to `width` and `height`. See details at https://github.com/postcss/postcss-size."
}
],
"pseudoClasses": [
{
"name": ":my-link",
"description": ":any-link pseudo class. See details at https://preset-env.cssdb.org/features#any-link-pseudo-class."
}
]
}
上述示例可在 octref/simple-customdata 中找到,而更完整的功能示例可在 octref/svg-data 中找到。
这些指南解释了数据格式以及如何通过设置和扩展贡献点使用它们。
扩展创作
扩展更改事件
新增了事件 extensions.onDidChange
,它在 extensions.all
数组更改时触发。这可能发生在扩展安装、卸载、启用或禁用时。请参阅安装扩展无需重新加载部分。
/**
* An event which fires when `extensions.all` changes. This can happen when extensions are
* installed, uninstalled, enabled or disabled.
*/
export const onDidChange: Event<void>;
注意:引入新贡献点的扩展作者应监听此事件并相应地更新工作台的状态。
在浏览器中打开资源
我们观察到有几个扩展使用 opn
或 open
等 Node 模块在浏览器中打开 URL。鉴于对这种功能的需求,我们添加了一个新的 API vscode.env.openExternal
。它需要一个 URL,可用于打开网站链接、邮件链接或应用程序 URL 处理程序。此外,也接受文件 URL,以便在它们的默认应用程序中打开它们,例如 PDF 文件。
// open default browser
await vscode.env.openExternal(
vscode.Uri.parse('https://github.com/microsoft/vscode/issues/66741')
);
注意:目前使用 opn
或 open
模块的扩展作者应切换到此新 API。
全局存储路径
扩展现在提供了一个全局存储路径 ExtensionContext.globalStoragePath
,指向具有读写访问权限的本地目录。如果您需要存储可从所有工作区访问的大文件,这是一个不错的选择。
/**
* An absolute file path in which the extension can store global state.
* The directory might not exist on disk and creation is
* up to the extension. However, the parent directory is guaranteed to be existent.
*
* Use [`globalState`](#_ExtensionContext.globalState) to store key value data.
*/
globalStoragePath: string;
VS Code 会在移除扩展时清理此路径。
注意:目前使用自定义文件系统位置来存储跨工作区状态的扩展作者应切换到此新 API。
CodeActionKind.intersects
CodeActionKind.intersects
方法对于检查 CodeActionProvider
是否应该计算其 Code Actions 很有用。
import * as vscode from 'vscode';
export class OrganizeImportsProvider implements vscode.CodeActionProvider {
public provideCodeActions(
document: vscode.TextDocument,
range: vscode.Range,
context: vscode.CodeActionContext,
token: vscode.CancellationToken
): vscode.CodeAction[] {
// Only return organize imports actions if they were explicitly requested
// We can check this using `intersects`.
if (!context.only || !vscode.CodeActionKind.SourceOrganizeImports.intersects(context.only)) {
// Organize imports actions were not requested
return [];
}
// Organize imports was requested
...
}
}
contributes.resourceLabelFormatters
扩展现在可以提供资源标签格式化程序,这些格式化程序指定如何在工作台中的任何位置显示 URI。例如,扩展可以像这样为带有方案 remotehub
的 URI 提供格式化程序:
"contributes": {
"resourceLabelFormatters": [
{
"scheme": "remotehub",
"formatting": {
"label": "${path}",
"separator": "/",
"workspaceSuffix": "GitHub"
}
}
]
}
这意味着所有具有 remotehub
方案的 URI 都将通过仅显示 URI 的 path
段进行渲染,并且分隔符将是 /
。具有 remotehub
URI 的工作区将在其标签中包含 GitHub 后缀。
向键盘绑定添加参数
在 package.json
中定义键盘绑定时,您现在可以定义参数。执行时,这些参数将传递给命令。
在下面的示例中,它是:{foo: 1, bar: 2}
。
"keybindings": {
"key": "cmd+i",
"command": "myCommand",
"args": {
"foo": 1,
"bar": 2
}
}
完全控制 createTerminal 环境
新设置 TerminalOptions.strictEnv
设置为 true 时,将完全不对终端环境进行任何修改,而是完全按照扩展传入的方式使用。
// This will create a terminal whose environment only contains the single value
// FOO=BAR.
const terminal = createTerminal({
name: 'Test terminal',
env: {
FOO: 'BAR'
},
strictEnv: true
});
Node.js 更新
VS Code 运行的 Electron 版本已更新,Node.js 也从 8.9
更新到 10.2.0
。所有扩展现在都将在更新的 Node.js 版本上运行。请查看 Node v10.0.0 弃用,了解 Node.js 10 中的弃用列表。
更新的 Octicons
我们已将 Octicons 版本更新到 8.3.0,现在支持以下图标:
$(arrow-both)
$(bold)
$(color-mode)
$(eye-closed)
$(fold-down)
$(fold-up)
$(grabber)
$(italic)
$(kebab-horizontal)
$(kebab-vertical)
$(note)
$(organization-filled)
$(person-filled)
$(project)
$(request-changes)
$(screen-full)
$(screen-normal)
$(smiley)
$(tasklist)
$(text-size)
$(unverified)
$(verified)
您可以阅读我们的文档以查看我们支持的图标的完整列表。有关更改的详细列表,请参阅 Octicon 更改日志。
建议的扩展 API
每个里程碑都附带新的提议 API,扩展作者可以试用它们。一如既往,我们渴望您的反馈。以下是试用提议 API 所需的操作:
- 您必须使用 Insiders 版本,因为提议的 API 经常更改。
- 您的扩展的
package.json
文件中必须包含以下行:"enableProposedApi": true
。 - 将最新版本的 vscode.proposed.d.ts 文件复制到您的项目中。
请注意,您不能发布使用提议 API 的扩展。我们很可能会在下一个版本中进行破坏性更改,我们绝不希望破坏现有扩展。
SignatureHelpContext.activeSignatureHelp
提议的 SignatureHelpContext.activeSignatureHelp
字段跟踪先前激活的签名。
import * as vscode from 'vscode';
class MySignatureHelpProvider implements vscode.SignatureHelpProvider {
provideSignatureHelp(
document: vscode.TextDocument,
position: vscode.Position,
token: vscode.CancellationToken,
context: vscode.SignatureHelpContext
): vscode.ProviderResult<vscode.SignatureHelp> {
// The active signature help when this provider was triggered or undefined if
// no signature help was active.
console.log(context.activeSignatureHelp);
...
}
}
提供者可以使用此功能来跟踪在签名帮助提供者重新触发之前选择了哪个重载。
自动修复和 CodeAction.isPreferred
代码操作 API 为 VS Code 的快速修复(您在编辑器中看到的灯泡)提供支持。尽管对于给定的错误可能存在许多快速修复,但通常其中一个快速修复是解决问题的最合理方法。例如,修复拼写错误通常比生成新字段更可能是正确的修复。
通过使用提议的 API,扩展可以在 CodeAction
上设置 isPreferred
,以指示这是解决潜在问题的最合理修复。可以使用自动修复命令 (⌥⌘. (Windows, Linux Shift+Alt+.)) 自动应用首选修复。
首选快速修复通常应该:
- 正确修复潜在错误(而不是抑制它)。
- 是错误的合理修复。
- 不会意外执行大量操作。
重构代码操作也可以标记为首选,以表明它们是最合理的重构。例如,虽然可能有多个提取常量重构可用,但用户通常只想提取到最近的局部变量。如果该重构代码操作标记为 isPreferred
,用户可以为其设置单个键盘绑定。
{
"key": "ctrl+shift+r ctrl+e",
"command": "editor.action.codeAction",
"args": {
"kind": "refactor.extract.constant",
"preferred": true
}
}
全部修复源操作
提议的 source.fixAll
CodeActionKind
为能够自动修复文件中错误的扩展建立了约定。这种新的源操作类型类似于组织导入,并使其易于配置全部修复操作的键盘绑定或启用保存时自动修复。
// On save, run both fixAll and organizeImports source actions
"editor.codeActionsOnSave": {
"source.fixAll": true,
"source.organizeImports": true,
}
TSLint 扩展已经使用此提议的源 CodeAction 类型来实现全部修复和保存时自动修复。
调试适配器协议
数据断点建议调试适配器协议
作为数据断点(AKA“观察点”)正在进行的工作的后续步骤,我们在数据断点的调试适配器协议设计方面取得了一些进展。建议的 DAP 更改位于此分支,相应的 TypeScript API 可以在数据断点建议中找到。
如果您有兴趣在调试器扩展中支持数据断点,请查看建议并提供反馈。
实时主题编辑
在开发颜色主题扩展时,您可以在扩展开发主机窗口中实时查看颜色更改。
文件图标主题也同样适用。
工程
Electron 3.0 更新和 Electron 4.0 探索
在此里程碑中,我们完成了将 Electron 3 捆绑到 VS Code 中的探索,这是我们首次将此 Electron 版本与稳定版一起发布。这是一个主要的 Electron 版本,附带 Chrome 66 和 Node.js 10.x(与我们当前版本中的 Chrome 61 和 Node.js 8.x 相比,这是一个巨大的飞跃)。
同时,我们开始探索更新到 Electron 4,我们希望很快将其推送到 Insiders。
更好的性能信息
在此版本中,开发人员:启动性能命令输出在编辑器中显示,不再在开发工具中显示。这使其更易于阅读和更快地获取信息。此外,许多信息问题已得到修复。
WinJS.Promise 移除 ✅
当 VS Code 刚开始时,JavaScript 还不像今天这样。例如,没有原生 Promise,因此团队决定使用 WinJS.Promise
来处理异步工作。今天,情况不同了:原生 Promise 是真实的,而 WinJS.Promise
已过时。去年年中,我们开始努力从代码库中移除 WinJS.Promise
,并于 12 月完成。
严格空值检查
我们继续努力对主 VS Code 代码库进行严格的 null 检查。感谢您的帮助,在这个里程碑中,我们能够为大量测试文件启用严格的 null 检查,从而消除了大量错误。
我们将在下一个里程碑中继续进行严格的 null 检查工作。
对扩展的贡献
我们的团队维护或贡献了许多 VS Code 扩展。本月最值得注意的是
TSLint 支持
新的 TSLint 扩展现在支持使用 source.fixAll
代码操作进行保存时自动修复。
"editor.codeActionsOnSave": {
"source.fixAll": true
}
我们建议所有已弃用的 TSLint (eg2.tslint) 扩展用户迁移到新的 TSLint 扩展。
Stylus 语言支持
Stylus 语言扩展现在使用来自 vscode-css-languageservice 的精选数据,提供最新的带状态警告和语法文档的完成。
GitHub 拉取请求
在此里程碑中,我们继续致力于改进 GitHub Pull Requests 扩展。
以下是一些新功能
- GitHub 审查支持。您现在可以将评论分组到审查中,而不是单独添加它们。
- 当工作区是 GitHub 仓库时,当您加入 Live Share 会话时,扩展程序可以无缝运行。
- 我们逐步将 GraphQL 引入项目,因此描述视图现在提供更详细的拉取请求信息,并且扩展的整体性能得到了改进。
- 您现在可以在合并拉取请求时选择创建合并提交、压缩并合并或变基并合并。
- 性能改进。当您浏览拉取请求、文件更改和检出拉取请求时,我们减少了对 GitHub 的 API 调用和 Git 操作,这使得扩展响应更快,尤其是在 Windows 上。
您可以在 vscode-pull-request-github 版本上阅读扩展的完整发行说明。
新文档
Python Jupyter Notebooks
新的使用 Jupyter Notebooks 主题描述了如何从 VS Code 中打开、调试和导出 Jupyter Notebooks。
改进的 JavaScript 和 TypeScript 文档
我们已经更新了 JavaScript 和 TypeScript 文章,以确保它们是最新的并提供更有用的信息。
“JavaScript”和“TypeScript”页面现在提供了 VS Code 为这些语言提供的功能的概述。这些功能的更详细解释和教程已分别移至目录中的“Node.js / JavaScript”和“TypeScript”下的新页面。
更新的扩展 API 文档
对于扩展作者,VS Code API 文档已重新编写并移至其自己的目录。
在这里您可以找到以下文章:
值得注意的修复
- 7570: VS Code 无法离线打开
- 14372: 扩展: 禁用状态需要在窗口间通信
- 34396: 单 CPU VM 上的高 CPU 使用率
- 58167: 恢复操作系统后,终端和缩略图恢复纹理损坏
- 59794: 当 editor.accessibilitySupport 设置为 'auto' 时,终端屏幕阅读器支持不起作用
- 61649: 调试无法读取未定义的属性 'onError'
- 63832: 调试扩展时无法附加到 lsp 服务器
- 64948: GDB C/C++ 调试器无法启动,报错
- 65697: node cluster fork 进程未遵守 autoAttachChildProcesses 的 debug stopOnEntry
- 66302: Ctrl + L 应默认绑定到清除 repl
- 66681: 虚拟文档未显示“选择进行比较”和“与选定项比较”命令
本次发布还包括 Microsoft 安全响应中心 CVE-2019-0728 的安全更新。
感谢
最后但同样重要的是,衷心感谢!以下帮助使 VS Code 变得更好的各位:
我们问题跟踪的贡献。如果您想帮助我们管理传入的问题,请参阅我们的社区问题跟踪页面。
- Alexander (@usernamehw)
- Simon Chan (@yume-chan)
- Prabhanjan S Koushik (@skprabhanjan)
- Eric Amodio (@eamodio)
- Christopher Leidigh (@cleidigh)
对 vscode
的贡献
- Alec Chan (@aechan): 搜索: 改进清除按钮行为 PR #63082
- Alexander Eyers-Taylor (@aeyerstaylor)
- Agustín Rodríguez (@agurodriguez): 防止“报告问题”和“进程资源管理器”窗口在全屏模式下打开 PR #64839
- Anirudh Rayabharam (@anirudhrb): 修复问题 65204: 打开键盘绑定图标消失 PR #65968
- @asaf050: 允许从终端上下文菜单中杀死终端 PR #66535
- Chris Patterson (@chrisrpatterson): 更新构建徽章 URL PR #67008
- Christian Alexander (@ChristianAlexander): 添加 git add -N 添加的文件显示处理 PR #59163
- Christian Flach (@cmfcmf): 为任务添加 terminalGroup 以允许它们在拆分窗格中运行 PR #65973
- Christian Oliff (@coliff): EditorConfig.org 的 HTTPS 链接 PR #65358
- Danny Tuppeny (@DanTup): 修复拼写错误: "accepeted" => "accepted" PR #64976
- @davidwu226: 修复无效的 JSON。 PR #65447
- Donald Pipowitch (@donaldpipowitch): 添加 .vscodeignore 语法高亮 PR #64960
- Thai Pangsakulyanont (@dtinth): 解析 tsconfig.json 时使用 jsonc.parse 而不是 JSON.parse,修复了 tsconfig.json 包含注释时
-b
标志未激活的错误。 PR #67535 - Thien Do (@dvkndn): 更新 nvmrc 到 node 8 PR #67183
- Ashwin Ramaswami (@epicfaace)
- Phil (@flurmbo): 检测 md 图像链接 PR #66958
- li zixiang (@fuafa): 为 findModel.test.ts 添加严格 null 检查 PR #66436
- Gabriel Arjones (@g-arjones): 修复 #59635 PR #60111
- @g1tman: 在终端不可见时,调整大小时不获取字体 PR #66781
- Gabriel DeBacker (@GabeDeBacker): 允许终端创建忽略 VSCode 的进程环境 PR #64733
- Chris Ganga (@gangachris)
- 启用 src/vs/base/test/common/async.test.ts 的严格 null 检查 PR #65442
- 启用 ./vs/base/test/common/keyCodes.test.ts 的严格 null 检查 PR #65454
- 启用 ./vs/base/test/common/octicon.test.ts 的严格 null 检查 PR #65458
- 启用 ./vs/base/test/node/config.test.ts 的严格 null 检查 PR #65471
- 启用 ./vs/base/test/common/event.test.ts 的严格 null 检查 PR #65444
- 启用 ./vs/base/test/common/history.test.ts 的严格 null 检查 PR #65453
- 启用 windowsFinder 的严格 null 检查 PR #65551
- 启用查找控制器的严格 null 检查 PR #65553
- Gaurav Gupta (@gaurav5430): 启用 ./vs/platform/contextkey/test/common/contextkey.test.ts 的严格 null 检查 PR #65474
- Guy Waldman (@guywald1): [git] 添加从特定引用创建分支的命令 PR #59078
- Henk Mollema (@henkmollema): 更新版权年份至 2019 PR #65875
- Ilya Biryukov (@IlyaBiryukov): 添加 Git 日志、globalConfig 和树差异 API PR #64826
- James Dinh (@jamesdinht): 启用文件测试的严格 null 检查 PR #65249
- James George (@jamesgeorge007): 在用户代码片段中添加多行描述支持 PR #66159
- Jimi (Dimitris) Charalampidis (@JimiC): [主题] 添加无需重启编辑器即可重新加载主题的功能 PR #66115
- Julia McGeoghan (@jkmdev)
- Joseph Duchesne (@josephduchesne): 修复 #58159,通过触发布局刷新来解决 xtermjs bug... PR #60221
- Josh Goldberg (@JoshuaKGoldberg)
- Krish De Souza (@Kedstar99)
- Kermit Xuan (@Kermit-Xuan)
- Claire (@krider2010): 允许完全禁用或手动更新,以及自动更新 PR #60973
- Kumar Harsh (@kumarharsh): fix(loc): 修复透明颜色描述中不正确的措辞 PR #66334
- Anton Marchenko (@marchenko-am): 修复 #64379 - SimpleFindWidget 位置已更改(在隐藏状态下) PR #64558
- Mathias Rasmussen (@mathiasvr): HTML 代码片段: 统一空标签 PR #66072
- Maksymilian Barnaś (@maxbarnas): #61410 为“在文件夹中查找”操作添加键盘绑定 PR #61526
- Mrigank Krishan (@Mrigank11): 请求将已知的大文件夹添加到 .gitignore,修复 #44304 PR #44562
- J.M. Rütter (@mynetx): 隐藏终端拆分时短暂显示的未定义标题 PR #61981
- Néstor Hernández Ojeda (@nesukun): 为 scm/git 上下文菜单添加强制推送条目 PR #60387
- Noj Vek (Manoj P) (@nojvek): 修复 #27107 - 用户终端的 cwd 用于链接 PR #64750
- Nuno Lopes (@nunottlopes): 修复在 Windows 上包含空格的路径中在终端运行活动文件的问题 PR #65331
- Oleg Voloshin (@oniondomes): 启用 workspaceStats 测试的严格 null 检查 PR #65429
- Raul Piraces Alastuey (@piraces): 为 suggestMemory.test.ts 添加严格 null 检查 PR #66754
- Prateek Singh (@punteek): 启用 simpleServices 测试的严格 null 检查 PR #65571
- Rich Evans (@rcbevans): 添加 xterm mouseleave 以关闭小部件 PR #66576
- Matthias Reitinger (@reima): 修复键盘绑定列表标题行为问题 (#_41558) PR #60217
- Romain Marcadier-Muller (@RomainMuller): 修复使用引用时“tsc watch”任务的问题 PR #67148
- Rudi Chen (@rudi-c): 为 breadcrumbs.ts、outlineModel.ts、breadcrumbsModel.ts 启用 strictNullChecks PR #65062
- Segev Finer (@segevfiner)
- @SimonEggert: 添加选项卡关闭顺序的设置 PR #66635
- Prabhanjan S Koushik (@skprabhanjan)
- Tereza Tomcova (@the-ress): 在 bootstrap.js 中正确处理 UNC 路径 PR #66128
- Tiago Ribeiro (@TiagoR98): 功能 #24344 已实现 PR #65072
- Tyler James Leonhardt (@TylerLeonhardt): 处理只有单引号但没有空格的边缘情况 PR #66359
- Alexander (@usernamehw)
- 启用 Comparers 测试的严格 null 检查 PR #65301
- 为 inspect TM 小部件添加对比度 PR #64495
- 启用 quickOpenScorer 测试的严格 null 检查 PR #65299
- 将光标移到大括号内 PR #67164
- 排除/包含 commandsToSkipShell,而不是破坏用户设置文件 PR #66179
- 启用 Notifications 测试的严格 null 检查 PR #65291
- 启用 snippetVariables 测试的严格 null 检查 PR #65236
- 启用 SplitView 测试的严格 null 检查 PR #65307
- 在主题/图标主题过滤器后添加空格 PR #64745
- 启用 GridView 测试的严格 null 检查 PR #65305
- 当脏状态在顶部边框中突出显示时,完全隐藏选项卡关闭按钮 PR #64718
- Dipen Ved (@vedipen)
- @vemoo: 修复命名多行问题模式解析 PR #65840
- Vladimir Kotikov (@vladimir-kotikov): 添加选项以在执行
git pull
之前自动暂存更改 PR #59849 - Jeremy Shore (@w9jds): 修复 #57910 - 添加自动抓取超时设置 PR #59988
- Matthew Walinga (@walinga): 使用 stage line cmd 时,暂存删除空末尾行 PR #59974
- Yisrael Veller (@YisraelV)
对 vscode-eslint
的贡献
- Jonathan T L Lee (@Lee182): 问题 529,增加了对 pnpm 的支持 PR #572
- Loune Lam (@loune): disable-eslint 修复和改进 PR #588
对 language-server-protocol
的贡献
- Laurent Tréguier (@LaurentTreguier): 移除重复的 label 属性 PR #638
- Jason Axelson (@axelson): 修复变更日志链接 PR #654
对 vscode-languageserver-node
的贡献
- Daniel McNab (@DJMcNab):
- Felix Becker (@felixfbecker): 将 repository.directory 字段添加到 package.json PR #439
- Laurent Tréguier (@LaurentTreguier): 修复配置并非总是使用资源范围的问题 PR #446
- Aleksey Kladov (@matklad): 在 readme 中提及
npm run symlink
PR #452
对 debug-adapter-protocol
的贡献
- Ben Jackson (@puremourning): 将 vimspector 添加到实现列表 PR #21
- Sean Allred (@vermiculus): 纠正概述中的各种拼写错误 PR #22
对 vscode-vsce
的贡献
- Alexander (@usernamehw): 向控制台消息添加颜色 PR #324
对 vscode-json-languageservice
的贡献
对 vscode-css-languageservice
的贡献
- Krister Kari (@kristerkari): 不警告 :export 块内的未知属性 PR #137
- Simon Chan (@yume-chan)
- Matthew Dean: 支持 Less 根函数、查找、匿名混合 PR #135
对 vscode-html-languageservice
的贡献
- Liam Newman (@bitwiseman): 更新到 1.9.0-beta1 PR #43
对 vscode-generator-code
的贡献
- Aurélien Pupier (@apupier): 遵循 markdownLint 换行指南 #154 PR #155
对 vscode-recipes
的贡献
- Alan Agius (@alan-agius4): docs: 更新 ng test 命令 PR #179
- Bryan Chapel (@bryanchapel): 更新 README.md PR #176
- @CannibalKush: angular 流程的修改 PR #177
- zhan ishzhanov (@janat08): 拆分 JEST 食谱的参数 PR #174
对 localization
的贡献
有超过 600 名 Cloud + AI 本地化社区成员使用 Microsoft 本地化社区平台 (MLCP),其中约 100 名是 Visual Studio Code 的活跃贡献者。
我们感谢您的贡献,无论是提供新翻译、对翻译投票,还是提出流程改进建议。
这是贡献者的快照。有关项目详细信息,包括贡献者姓名列表,请访问项目网站:https://aka.ms/vscodeloc。
- 保加利亚语:Любомир Василев。
- 捷克语: Samuel Tulach。
- 丹麦语: Johan Fagerberg。
- 荷兰语: Jos Verlinde,Eric Algera。
- 芬兰语: Petri Niinimäki, Valtteri Vatanen。
- 法语: Mohamed Sahbi, Thomas Gouthière。
- 德语: Frank Lindecke,Hans Meiser,Jakob von der Haar,Sebastian Seidl。
- 希伯来语: Kyle Orin。
- 印地语: Satish Yadav,nirav adatiya,shaswat rungta,Dhanvi Kapila。
- 匈牙利语: Péter Nagy。
- 简体中文: 福永 叶, Xiangrui Kong, Licheng Ren, Young Bige, 文 陈, Y F, 彦佐 刘, 九鼎 谭。
- 印度尼西亚语: Azhe Kun。
- 意大利语: Michael Longo。
- 日语: nh,Masakazu TENMYO, 裕子 知念。
- 韩语: SeungJin Jeong。
- 挪威语: Stephan Eriksen。
- 波兰语: grzegorz m, Jakub Jedryszek。
- 葡萄牙语 (巴西): Bruno Talanski, Alan Willian, Letticia Nicoli, Alessandro Fragnani, Cynthia Zanoni。
- 葡萄牙语 (葡萄牙): Vitor Barbosa。
- 西班牙语: Engel Aguilar, José María Aguilar, julian3xl, Alvaro Enrique Ruano, Ing. Sergio Uziel Tovar Lemus, Mario Mendieta。
- 泰米尔语: Mani M。
- 土耳其语: Muhammed Emin TİFTİKÇİ。
- 乌克兰语: Did Kokos。
- 越南语: Việt Anh Nguyễn。