在 VS Code 中尝试

2018 年 9 月 (版本 1.28)

更新 1.28.2:此更新解决了这些问题

更新 1.28.1:此更新解决了这些问题

下载:Windows:x64 | Mac:Intel | Linux 64 位:deb rpm tarball | 32 位:deb rpm tarball


欢迎使用 2018 年 9 月发布的 Visual Studio Code。正如9 月迭代计划中所宣布的那样,我们专注于整理 GitHub 问题和拉取请求。在所有 VS Code 存储库中,我们关闭了(分类或修复)3918 个问题。在关闭问题期间,您创建了 2187 个新问题。这导致问题净减少了 1731 个。主 vscode 存储库目前有 2472 个开放功能请求和 625 个开放 Bug。此外,我们关闭了 212 个拉取请求。

很高兴看到您如此关心我们的进展。Benjamin Lannon 发布了一个个人网站,其中包含我们主存储库中问题数量的实时跟踪器。它清晰地展示了我们自 9 月 11 日以来取得的进展。

Burn down of issues

它还显示了一旦我们停止关注减少问题时会发生什么。以下是上周我们为本次发布做准备的最后三天。如您所见,未来我们将有更多的问题整理迭代。

Increase of issues

在此整理里程碑期间,我们解决了一些功能请求,社区拉取请求也带来了新功能。以下是本次发布的一些亮点

如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新
您还可以观看 Cloud Developer Advocate Brian Clark 制作的 1.28 版本亮点视频

Insiders:想尽快看到新功能吗?您可以下载每晚Insiders 构建版本,并在它们可用时立即试用最新更新。

工作台

Windows 默认使用自定义标题栏和菜单栏

之前发行说明中描述的自定义标题栏和可主题化菜单现在在 Windows 上默认启用。设置 "window.titleBarStyle" 在上个月的 Insiders 版本中已在 Windows 上默认为 "custom",我们现在准备将其作为默认体验。

Custom title and menu bar with a dark theme on Windows

按文件类型显示文件图标

在 macOS 和 Windows 上,VS Code 注册为众所周知文件类型的默认编辑器。VS Code 现在为一些常见的 VS Code 文件类型提供自定义图标。当图标大小配置为中等到大时,这些图标将显示在操作系统资源管理器中。对于小图标尺寸,我们决定保留 VS Code 徽标作为图标。

File Icons

项目级代码片段

代码片段现在可以限定到项目并与您的团队共享。只需使用首选项:配置用户代码片段命令或在 .vscode 文件夹中创建 *.code-snippets 文件。项目代码片段的工作方式与其他代码片段一样,它们显示在 IntelliSense 中和插入代码片段操作中,现在它们拥有自己的类别。

Project Level Snippet

代码片段现在还支持多个前缀。如果您无法决定您的版权标题代码片段应该使用 headerstubcopyright 作为前缀,您可以全部拥有。只需使用字符串数组作为 prefix 属性。

{
  "prefix": ["header", "stub", "copyright"],
  "body": "Copyright. Foo Corp 2028",
  "description": "Adds copyright...",
  "scope": "javascript,typescript"
}

长期以来,VS Code 在打开文件夹时一直在解析符号链接。这意味着即使符号链接有其原因,VS Code 也会忽略它并始终打开解析后的链接路径。我们决定更改此行为并保留符号链接。

注意:当将文件夹作为符号链接打开时,某些功能将以受限功能运行(例如调试Git 集成)。

记录和搜索键盘快捷方式

在键盘快捷方式编辑器中(⌘K ⌘S (Windows, Linux Ctrl+K Ctrl+S)),您现在可以通过键入击键来搜索键绑定,而不是键入键名(例如“shift”)。打开录制按键模式并键入您要搜索的击键。

Record Keys

您也可以使用⌥⌘K (Windows, Linux Alt+K) 进入录制按键模式。按 Esc 键退出录制按键模式。

切换面板更改

我们决定重新审视切换面板(终端、输出、问题、调试控制台)命令的行为。您可以关注问题19400 以了解更改的背景。

行为是

  • 如果不可见,则显示面板。
  • 如果可见,则隐藏面板。

行为是

  • 如果不可见,则显示面板。
  • 如果面板具有键盘焦点,则隐藏。
  • 如果面板可见但未聚焦,则获得焦点。

要恢复以前的行为,您可以在相关面板处于活动状态时配置一个键绑定以关闭面板。

例如,对于输出面板

{
  "key": "cmd+shift+u",
  "command": "workbench.action.closePanel",
  "when": "activePanel==workbench.panel.output"
}

面板标识符列表是

  • terminal - 集成终端
  • workbench.panel.markers - 问题面板
  • workbench.panel.output - 输出面板
  • workbench.panel.repl - 调试控制台面板

复制相对路径

将文件路径复制为相对路径的命令现在在文件资源管理器和编辑器选项卡的上下文菜单中更显著地暴露出来。

Copy Relative Path

从快速打开中排除最近打开的文件

新设置 search.quickOpen.includeHistory 允许您控制最近打开的文件是否应成为快速打开文件选择器的一部分。默认情况下,最近打开的文件将显示在搜索的顶部,工作区中的其他文件显示在下方。如果您不想在顶部看到最近打开的文件,可以将此设置更改为 false

删除文件时禁用回收站

如果您在从资源管理器删除文件时遇到问题,因为它们移动到操作系统回收站,您现在可以将 files.enableTrash 设置为 false 以永不使用操作系统回收站进行删除。这样做将更改文件资源管理器上的删除操作和键绑定,以绕过操作系统回收站并永久删除。在删除发生之前,您仍然会看到提示。

如果检测到工作区文件,则提示打开

当打开一个包含一个或多个 .code-workspace 文件的根文件夹时,VS Code 现在会显示一个通知,询问您是否要改为打开工作区文件。打开工作区文件通常会提供比仅仅打开文件夹更好的体验。您可以在我们的文档中了解有关多根工作区的更多信息。

Workspace file prompt

重新打开文件时不恢复视图状态

VS Code 始终会记住文件的视图状态(光标位置、折叠部分等),即使文件已关闭。现在有一个新设置 workbench.editor.restoreViewState,用于在文件关闭时丢弃此视图状态。这允许您在重新打开文件后始终从文件的顶部开始。

关闭所有编辑器组中的文件

新命令关闭所有组中的编辑器workbench.action.closeEditorInAllGroups)允许您关闭所有编辑器组中当前活动的文件。

问题面板

显示错误代码

问题面板现在显示问题的错误代码(如果有)。

Problems panel shows error codes

改进的键盘导航

问题面板现在对键盘更友好

  • 当面板获得焦点时,您可以开始输入以进行过滤。
  • 您可以使用⌘F (Windows, Linux Ctrl+F) 将焦点置于筛选框,使用⌘↓ (Windows, Linux Ctrl+Down) 将焦点从筛选框移到问题列表。

用于遥测事件的输出通道

在七月版本中,我们添加了一项功能,当您使用开发人员:设置日志级别...命令将日志级别设置为跟踪时,VS Code 发送的所有遥测事件也会记录到本地文件。您现在可以在输出面板的日志(遥测)通道中查看此文件的内容。和以前一样,您可以使用开发人员:打开日志文件...命令直接查看文件。

聚焦自定义视图

您现在可以使用命令将焦点置于自定义视图。每个自定义视图都提供了单独的命令。

Custom view focus commands

Linux URL 处理

以前仅限于 Windows 和 macOS 的功能,现在您也可以在 Linux 上打开 VS Code URL!这些 URL 对于许多不同的功能非常有用,例如自动安装扩展,例如 vscode-insiders:extension/vscodevim.vim

编辑器

Tab 补全

编辑器 Tab 补全现在可以补全所有类型的建议。设置 "editor.tabCompletion": "on" 后,按 Tab 键将补全任何前缀,而不仅仅是代码片段。此外,按 Tab 将插入下一个建议,按 ⇧Tab (Windows, Linux Shift+Tab) 将插入上一个建议。

Tab completion

导航到上次编辑位置

添加了一个新命令转到上次编辑位置workbench.action.navigateToLastEditLocation),用于快速导航到文件中上次编辑的位置。默认键绑定是⌘K ⌘Q (Windows, Linux Ctrl+K Ctrl+Q)

保存而不格式化

新命令保存而不格式化workbench.action.files.saveWithoutFormatting)可用于保存文件而不触发任何保存参与者(例如,格式化程序、删除尾随空格、最终换行符)。默认键绑定是⌘K S (Windows Ctrl+K Ctrl+Shift+S, Linux Ctrl+K S)。这在编辑您的正常项目之外的文件时非常有用,因为它们可能具有不同的格式约定。

IntelliSense 本地化奖励

建议现在可以根据它们与光标的距离进行排序。设置 "editor.suggest.localityBonus": true 后,您将看到(例如)函数参数显示在 IntelliSense 列表的顶部。

Locality bonus

Emmet

本次迭代我们对 Emmet 功能进行了一些改进

  • 如果您在 JavaScript 文件中启用了 Emmet,那么您现在可以在 HTML 文件中的 <script> 标签内展开 Emmet 缩写。
  • Emmet: 使用缩写包装功能不再仅限于扩展名为 .html 的文件。
  • 即使没有选择,Emmet: 平衡(向内)功能现在也适用于当前节点。
  • 在 SCSS 文件中错误地将带有 # 的 CSS 选择器视为有效缩写的错误现已修复。

源代码管理

更改 SCM 提交键绑定

您现在可以使用 scm.acceptInput 命令更改在 SCM 视图中接受提交消息的默认键绑定。

SCM 状态栏跟踪活动文件

左下角的 SCM 状态栏贡献现在跟踪当前活动文件所属的存储库。这减少了在多文件夹工作区中编辑文件时的混淆。

Git 集成

更好地处理删除冲突

VS Code 始终检测到删除冲突。现在,有了更好的 UI 流程来处理它们,当打开更改时,您将看到未删除的版本,并且您可以决定暂存文件时文件的处理方式:保留它或删除它。

Keep or delete deletion conflicts

配置长提交消息警告阈值

git.inputValidationLength 设置现在允许您配置提交消息在编辑时出现警告之前必须有多长。

'git init' 后将文件夹添加到工作区

初始化 Git 存储库后,VS Code 现在会询问您是否要将其添加到当前工作区。

配置分支验证规则

您现在可以使用强大的 git.branchValidationRegexgit.branchWhitespaceChar 设置来控制分支名称验证的工作方式。有关更多详细信息,请参阅问题50241

运行同步时始终 rebase

git.rebaseWhenSync 设置将允许您配置同步命令在运行时始终使用 rebase 而不是 merge。

禁用进度报告

使用 git.showProgress 设置,您现在可以在 Git 操作期间禁用显示进度。

强制推送 --force

在您的日常开发中,有时您就是想冒险。运行 git push --force 就是一个很好的例子!VS Code 现在允许您强制将提交推送到远程,而无需进入终端。使用 git.allowForcePushgit.useForcePushWithLeasegit.confirmForcePush 设置来控制此行为。有关更多详细信息,请参阅问题53286

存储应用

以下 git stash apply 命令现在全局命令面板中提供:Git: 应用存储...Git: 应用最新存储

始终可见的暂存更改部分

您现在可以使用 git.alwaysShowStagedChangesResourceGroup 设置,即使在为空时,也始终保持 SCM 视图中的暂存更改部分可见。

Staged changes visible

终端

定义发送自定义序列的键绑定

已添加新命令 workbench.action.terminal.sendSequence,允许您直接将自定义序列发送到活动终端。这允许使用 \u 格式发送 Unicode 字符来发送箭头键、回车等。

{
  "key": "ctrl+u",
  "command": "workbench.action.terminal.sendSequence",
  "args": { "text": "\u001b[1;5D\u007f" }
}

查找改进

终端中的查找已得到改进,现在行为更像编辑器中的查找

  • 支持正则表达式、区分大小写和匹配单词。
  • 标准的查找下一个/上一个键绑定(F3、Shift+F3)现在可以正常工作。
  • 返回跨行换行的查找结果。

语言

TypeScript 3.1

VS Code 1.28 附带 TypeScript 3.1.1。此版本带来了新的语言功能,例如可映射的元组和数组类型,以及许多工具改进和 Bug 修复。

重命名导入路径

发现导入的文件可以使用更好的名称?现在只需重命名导入即可重命名引用的文件

Renaming an JavaScript import to rename a file

转换为异步函数

JavaScript 和 TypeScript 的新建议转换为异步函数重写了使用 .then Promise 链的函数,使其使用 asyncawait

Converting a promise chain to an async function

请注意,此功能要求设置 javascript.validate.enable 为 true。

JS/TS 建议的新设置

我们清理了 JavaScript 和 TypeScript 建议的设置名称,并添加了一些提供更精细控制的其他设置

  • 所有与建议相关的设置现在都在 javascript.suggest.*typescript.suggest.* 下。
  • typescript.useCodeSnippetOnMethodSuggest 已重命名为 javascript.suggest.completeFunctionCallstypescript.suggest.completeFunctionCalls
  • javascript.nameSuggestions 已重命名为 javascript.suggest.names
  • typescript.autoImportSuggestions.enabled 已重命名为 javascript.suggest.autoImportstypescriptscript.suggest.autoImports
  • 新的 javascript.suggest.enabledtypescript.suggest.enabled 允许您完全禁用 JS 或 TS 建议。

分号作为 JS/TS 的提交字符

分号现在是 JavaScript 和 TypeScript 建议的提交字符。这意味着您只需键入 ; 即可接受当前建议。现有的提交字符还包括 .(

您可以通过设置 "editor.acceptSuggestionOnCommitCharacter": false 来禁用提交字符。

HTML 和 CSS 路径补全排除点文件

. 开头的文件现在从路径补全结果中排除。

更好的 Markdown 折叠

多行列表、栅栏式代码块和原始 HTML 现在可以在 Markdown 文件中折叠

Folding Markdown code blocks and lists

在 Markdown 预览中,点击本地文件的链接现在将打开该文件的预览

Local file link open in preview

这使得浏览文档更容易。使用 markdown.preview.openMarkdownLinks 设置来配置链接的处理方式。有效的设置值为

  • inEditor - 在编辑器中打开本地 Markdown 链接。
  • inPreview - 在当前预览中打开本地 Markdown 链接。这是新的默认行为。

扩展

搜索筛选改进

您现在可以使用 @category 筛选器以及其他已安装扩展的筛选器,例如 @installed@enabled@disabled@outdated,来构成您的扩展搜索查询。例如,您可以使用查询 @installed @category:themes 搜索已安装的主题,或使用 @installed @category:snippets 搜索贡献代码片段的已安装扩展。

禁用的扩展不计为过期

活动栏上显示过期扩展计数的扩展视图徽章现在将排除禁用的扩展。此徽章的目的是让您知道有您可能想要更新的过期扩展。由于禁用的扩展目前未在使用,将其计入只会分散注意力。

扩展主机无响应

VS Code 在一个单独的进程中执行扩展,该进程称为扩展主机。此进程使用消息传递与渲染器/UI 进程通信。我们已添加更好的消息跟踪到扩展主机,如果消息在 10 秒内未得到确认,我们将显示以下通知

Extension Host Unresponsive

这意味着什么:很可能某个扩展正在执行 CPU 密集型操作,最终导致扩展主机进程阻塞超过 10 秒

如何操作:一种选择是等待操作完成,并简单忽略通知。另一种选择是调查哪个扩展导致 CPU 使用率过高,方法是转到正在运行的扩展视图并开始分析扩展主机。然后,您可以直接针对有问题 的扩展创建问题。最后,如果您认为扩展已进入无限循环,并且似乎无法恢复,您可以重新启动扩展主机。

工程

扩展和 webpack

我们继续了我们的 webpack 工作,现在大多数捆绑的扩展都已 webpack 化。回顾一下:这有助于缩短扩展的启动时间,因为要加载的文件更少,要解析的源代码也更少。它还有助于缩短安装时间,因为需要解压缩和写入磁盘的文件更少。

本次里程碑,我们又削减了 2803 个文件。7 月我们从 9000 个文件开始,到 8 月我们降到 4650 个,9 月我们只有 1847 个!

预览功能

预览功能尚未准备好发布,但功能足够强大,可供使用。我们欢迎您在它们开发期间提供早期反馈。

持续探索 Electron 3.0

在此里程碑期间,我们继续探索将 Electron 3.0.0 捆绑到 VS Code 中。这是一个主要的 Electron 版本,附带 Chrome 66 和 Node.js 10.x(与我们当前拥有 Chrome 61 和 Node.js 8.x 的版本相比,这是一个巨大的飞跃)。我们计划在不久的将来向 Insiders 用户推出更新,以收集更多反馈。如果您有兴趣提供帮助,请务必安装 VS Code Insiders

杂项

macOS Mojave 上的模糊

如果您已更新到 macOS 10.14 (Mojave),您可能会注意到,如果您没有使用高 DPI 显示器,VS Code 中的字体会看起来模糊。

解决方法是在终端中运行

defaults write com.microsoft.VSCode.helper CGFontRenderingFontSmoothingDisabled -bool NO

然后重新启动计算机。

请注意,此更改对每个应用程序都是全局的,不特定于 VS Code。有关相关讨论,请参阅问题51132

Electron 更新

在此版本中,我们将 Electron 从 2.0.7 更新到 2.0.9。最值得注意的是,这允许 VS Code 再次在 ArchLinux 上运行(问题55934)。

扩展创作

处理未安装扩展的 URL

早在 7 月,我们就发布了 URI 处理程序 API,允许扩展处理系统范围的 URI。通过最新版本,VS Code 甚至可以处理尚未安装的扩展的 URI。一旦用户打开此类 URI,VS Code 将在 Marketplace 中搜索该扩展,建议用户安装它,并启动 VS Code 并传入 URI。这允许扩展具有流畅的启动流程,将用户从网页带到以特定状态运行扩展。

诊断错误代码

由于诊断错误代码现在显示在问题面板中,扩展不再需要将错误代码添加到Diagnostic.message 属性中。

更好的配置 when 子句

在编写键绑定或菜单可见性时,会使用when 子句。在 when 子句中,您可以通过在其前面加上 config. 来引用配置(设置)值,例如 config.editor.tabCompletion。以前只支持布尔配置属性,但此版本中您还可以使用字符串和数字值。

更改文本文档的语言

有一个新的 API 函数可以更改文档的语言模式,vscode.languages.setTextDocumentLanguage。该 API 接受一个文档和您要使用的语言标识符。要了解哪些语言 ID 可用,请使用 vscode.languages.getLanguages

workspaceContains 激活

扩展可以使用 workspaceContains 激活事件,以便在打开包含匹配特定模式的文件的 Workspace 时激活。例如,一个 PHP 扩展可能会要求在打开包含匹配 **/*.php 文件的 Workspace 时激活。这并不是新功能,但用户指出,当打开大型 Workspace 时,搜索过程可能会运行很长时间并占用大量 CPU。

我们做了一些更改,以减少这些搜索的影响。首先是这些搜索现在将遵守用户的 files.excludesearch.excludesearch.useIgnoreFiles 设置。换句话说,如果用户无法通过普通文本搜索或快速打开的文件搜索找到文件,则 workspaceContains 模式将不会匹配该文件。这大大减少了我们必须搜索 workspaceContains 的文件数量,并减少了当它匹配一个实际上不属于项目的文件时(例如,某些文件埋在 node_modules/ 中)的错误激活。

第二个变化是为这些搜索设置 7 秒的限制。如果搜索在 7 秒后仍未完成,我们将终止搜索进程并无论如何激活扩展。

总的来说,这应该会减少在 VS Code 中打开大型工作区后笔记本电脑神秘发热的情况。

新主题颜色

有新的主题颜色

  • menu.separatorBackground:菜单中分隔符菜单项的颜色。
  • sideBarSectionHeader.border:侧边栏部分标题边框颜色。
  • inputValidation.infoForeground:信息严重性输入验证前景颜色。
  • inputValidation.warningForeground:警告严重性输入验证前景颜色。
  • inputValidation.errorForeground:错误严重性输入验证前景颜色。
  • editor.snippetTabstopHighlightBackground:代码片段制表符停靠点的突出背景颜色。
  • editor.snippetTabstopHighlightBorder:代码片段制表符停靠点的突出边框颜色。
  • editor.snippetFinalTabstopHighlightBackground:代码片段最终制表符停靠点的突出背景颜色。
  • editor.snippetFinalTabstopHighlightBorder:代码片段最终制表符停靠点的突出边框颜色。
  • activityBar.inactiveForeground:活动栏项非活动时的前景颜色。

调试 API

resolveDebugConfiguration 需要显式返回 null 才能打开 launch.json

以前,如果 resolveDebugConfiguration 返回的启动配置没有 type 属性,VS Code 会自动打开底层 launch.json 文件。在收到扩展作者的反馈后,我们决定让扩展对此场景拥有更多控制权。

现在 resolveDebugConfiguration 必须显式返回 null 值,以防止调试会话启动并改为打开 launch.json。返回 undefined 值只会阻止调试会话启动。与以前一样,返回具有 type 属性的配置将启动调试会话。

建议的扩展 API

每个里程碑都会带来新的建议 API,扩展作者可以尝试它们。我们一如既往地期待您的反馈。以下是尝试建议 API 的方法

  • 您必须使用 Insiders,因为建议 API 经常更改。
  • 您必须在扩展的 package.json 文件中包含以下行:"enableProposedApi": true
  • 将最新版本的 vscode.proposed.d.ts 文件复制到您的项目中。

请注意,您不能发布使用建议 API 的扩展。我们很可能会在下个版本中进行重大更改,我们绝不希望破坏现有扩展。

调试 API

新的 DebugConfigurationProvider.provideDebugAdapter 取代了 DebugConfigurationProvider.debugAdapterExecutable 命令

此前我们添加了建议的 API DebugConfigurationProvider.debugAdapterExecutable,以便扩展可以为即将由 VS Code 启动的调试适配器返回动态计算的路径(和相应的程序参数)。在此里程碑中,我们根据收到的反馈(例如 #45220#56646#57706#54465)修订了初始设计。

新 API 方法名为 provideDebugAdapter,现在我们传入调试会话、工作区文件夹、package.json 中的可执行文件信息以及解析后的启动配置。有了这些信息,扩展在被要求创建调试适配器时就有了“全貌”。

此外,我们现在支持更多启动和连接到调试适配器实现的方式。为此,可以从 provideDebugAdapter 方法返回一个描述符对象

  • DebugAdapterExecutable 描述符可用于将调试适配器作为每个会话的外部进程启动,并通过 stdin/stdout 与其通信。通过新 API,现在可以为调试适配器指定工作目录和环境变量。
  • DebugAdapterServer 描述了一个处理多个会话并通过套接字通信的服务器进程。
  • DebugAdapterImplementation 可用于无需通信开销的就地实现。此选项依赖于对基于 Node.js 的 DAP 客户端库的少量修改,并计划于 10 月推出。

请注意,这是建议的 API,不能用于在 Marketplace 上发布的扩展。但是,我们非常感谢您对问题45220DebugConfigurationProvider.provideDebugAdapter 的反馈。

评论编辑和删除

在上次迭代中,我们引入了 DocumentCommentProvider,允许扩展在编辑器中创建和管理评论。我们为此提供程序添加了新方法,以支持评论的编辑和删除。评论本身现在也具有标志,指示它们是否支持编辑或删除。如果扩展设置了其中一个标志并提供了适当的编辑或删除方法,当鼠标悬停或聚焦于编辑器中的评论时,将显示编辑或删除评论的操作

Comment editing

新命令

命令 命令 ID
⌘K ⌘Q (Windows, Linux Ctrl+K Ctrl+Q) 导航到上次编辑的位置 workbench.action.navigateToLastEditLocation
⌘K S (Windows Ctrl+K Ctrl+Shift+S, Linux Ctrl+K S) 保存文件而不运行保存参与者(格式化程序等) workbench.action.files.saveWithoutFormatting
关闭所有编辑器组中的活动文件 workbench.action.closeEditorInAllGroups
切换差异编辑器内联和并排模式(废弃 toggle.diff.editorMode toggle.diff.renderSideBySide

新文档

GitHub Pull Request 扩展博客文章

您可以阅读 Kenneth 最近的博客文章,宣布新的GitHub Pull Request 扩展并讨论 VS Code 与 GitHub 编辑器团队之间的协作。

使用 Azure Pipelines 博客文章

Visual Studio Code 使用 Azure Pipelines中,VS Code 工程师 João Moreno 描述了 VS Code 如何现在使用Azure Pipelines 作为其构建和持续集成 (CI) 基础设施。

新 PowerShell 主题

Visual Studio Code 中的 PowerShell 展示了通过 Microsoft PowerShell 扩展实现的 PowerShell 集成。该扩展支持强大的语言功能,例如 IntelliSense、转到定义和查找所有引用,以及调试和代码片段。

新 Python Django 教程

有一个新的在 Visual Studio Code 中使用 Django 教程,展示了如何在 VS Code 中快速创建、编辑和调试 Python Django Web 应用程序。

值得注意的修复

  • 48051:格式化后需要向左滚动
  • 31619:必须通过代码片段中已删除的制表符停靠点
  • 58327:调试工具栏按钮已禁用
  • 35935:“清除最近打开”也应清除编辑器快速选择历史记录
  • 58799:保存时显示无标题文件
  • 29553:在 Escape 时保留快速打开输入
  • 58222:UriDisplayService 缺少远程共享路径名
  • 54213:中止调试启动而不显示 launch.json 的机制
  • 52511:调试悬停窗口小部件 - 启用长项目溢出隐藏时窗口小部件的大小调整
  • 50569:如果断点已禁用,条件断点提示应提供启用断点
  • 42737:扩展:允许右键单击以调出齿轮菜单
  • 58434:使用 --force 参数以防止从 CLI 安装扩展时出现提示。

感谢

最后但同样重要的是,衷心感谢!以下各位为使 VS Code 变得更好所做的贡献

vscode 的贡献

language-server-protocol 的贡献

vscode-languageserver-node 的贡献

debug-adapter-protocol 的贡献

vscode-recipes 的贡献

vscode-chrome-debug 的贡献

vscode-chrome-debug-core 的贡献

  • @digeff
    • 更新日志记录机制,不记录源 PR #355
    • 修复 Chrome 69 的第一行 BP PR #352
    • 修复加载时中断以使附加断点工作 PR #332

localization 的贡献

Transifex VS Code 项目团队有近 1200 名成员,每月约有 100 名活跃贡献者。我们感谢您的贡献,无论是提供新翻译、投票翻译还是提出流程改进。

以下是本次发布贡献者的快照。有关项目(包括贡献者姓名列表)的详细信息,请访问项目网站:https://aka.ms/vscodeloc

  • 孟加拉语:Anisuzzaman Khan, abm_prottoy, Mushiar Khan, Mehedi Hassan。
  • 保加利亚语:Любомир Василев。
  • 克罗地亚语:Nikša Mihaica。
  • 捷克语:Vít Staniček。
  • 丹麦语:Kenneth Greig, Johan Fagerberg, Martin Fruensgaard。
  • 荷兰语:Gerald Versluis, Marco van den Hout。
  • 法语:Antoine Griffard, MayakoLyyn, Smrman, Etienne Blanc-Coquand。
  • 德语:J.M., Carsten Kneip, Volkmar Rigo, SetTrend。
  • 希腊语:Nikolaos Maliakkas。
  • 印地语:Ashwini Gupta, Shaswat Rungta。
  • 匈牙利语:Tar Dániel。
  • 简体中文:Joel Yang, 子实 王, pluwen, Chris Pan 潘冬冬, danyeh。
  • 繁体中文:Duran Hsieh, Poy Chang, Alan Tsai, Han Lin, Shih-Ming Tung, Will 保哥。
  • 印度尼西亚语:G-RiNe Project, Wildan Mubarok, Rizki A. Wibowo, Riwut Libinuko, Azhe-kun, rodin, Febrian Setianto (Feber)。
  • 意大利语:Luigi Bruno, Luca Bruni, Alessandro Alpi, Emilie Rollandin, Pascal Brax, Andrea Dottor, Riccardo Cappello。
  • 日语:Satoshi Kajiura, Shunya Tajima, Yuichi Nukiyama, yoshioms, daisuke osada (daiskeh)。
  • 韩语:Kyunghee Ko, jaeyeon Kim, Junseong Jang, Jisan Oh。
  • 立陶宛语:Martynas Jusys。
  • 马拉雅拉姆语:Kiren Paul。
  • 挪威语:Espen Klein Nilsen。
  • 波兰语:Artur, Patryk Brejdak, Adam Borowski, Mateusz Wyczawski。
  • 葡萄牙语(巴西):Roberto Fonseca, Bruno Sonnino, Danilo Dantas, Marcelo Fernandes, Thiago Custodio, Rodrigo Crespi, Marcelo Andrade, Alessandro Fragnani, Lucas Miranda, Otacilio Saraiva Maia Neto。
  • 葡萄牙语(葡萄牙):António Santos,Diogo Barros, António Lourenço, jp2masa, Ruben Mateus, Henrique Silva, André Vala。
  • 俄语:Ivan Kuzmenko, Roman Slauta。
  • 西班牙语:Jorge Serrano Pérez, José M. Aguilar, Alberto Poblacion, Carlos Mendible, Alejandro Medina, Andy Gonzalez,Carlos Herrera。
  • 泰米尔语:Vijay Nirmal, rajakvk, Anand AV。
  • 土耳其语:Mustafa Turhan, Fırat Payalan, Selim Ata。