尝试 VS Code 中的

2019 年 4 月 (版本 1.34)

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

欢迎使用 2019 年 4 月发布的 Visual Studio Code。在 4 月份,我们忙于 远程开发 扩展的预览版发布。这些扩展让您可以通过 SSH 在远程机器或虚拟机上、在适用于 Linux 的 Windows 子系统 (WSL) 中或在 Docker 容器内使用 VS Code 进行工作。您可以阅读 使用 Visual Studio Code 进行远程开发 博客文章以了解更多信息。

此版本中仍有许多更新以及大量社区贡献,我们希望您会喜欢。

如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的 更新 页面。

编辑器

稳定的 CodeLens

VS Code 现在会乐观地缓存 CodeLens 位置,并在切换编辑器后立即恢复它们。这修复了在编辑器之间切换时 CodeLens 行会略微移动的问题。

Stable CodeLens

语言

带有供应商前缀的 CSS 属性值排名较低

以破折号 '-' 为前缀的 CSS 属性值(例如 -moz-grid-ms-grid)现在在自动完成中位于 grid 之后。

调试

debug.showSubSessionsInToolBar

我们引入了设置 debug.showSubSessionsInToolBar,它控制调试子会话是否显示在调试工具栏中。当此设置为 false 时,子会话上的停止命令也将停止父会话。此设置的默认值为 false。

任务

终止所有任务

任务: 终止任务 命令新增了一个选项,可以在有多个任务运行时终止所有任务。如果这是您经常执行的操作,您可以为该命令创建一个带 terminateAll 参数的键盘快捷方式。

{
  "key": "ctrl+k t",
  "command": "workbench.action.tasks.terminate",
  "args": "terminateAll"
}

自动显示“问题”面板

新的 revealProblems 任务属性允许您自动显示“问题”面板。属性值为 alwaysneveronProblem

{
  "version": "2.0.0",
  "tasks": [
    {
      "type": "npm",
      "script": "watch",
      "problemMatcher": "$tsc-watch",
      "isBackground": true,
      "presentation": {
        "reveal": "always",
        "revealProblems": "onProblem"
      }
    }
  ]
}

对扩展的贡献

预览:远程开发

注意: 远程开发扩展 需要 Visual Studio Code Insiders

Visual Studio Code 远程开发 允许您将容器、远程机器或 适用于 Linux 的 Windows 子系统 (WSL) 用作功能齐全的开发环境。

远程开发扩展包 中的扩展在远程工作区的上下文中运行,而 VS Code 感觉就像在本地运行时一样。

Vetur

Vetur 扩展现在为 Vue 模板插值区域内的 JavaScript 表达式提供语义诊断、悬停信息、跳转到定义和查找引用功能。

Vetur JavaScript support in interpolations

您可以在 Vetur 文档 中阅读有关此功能的更多信息。

其他改进包括内存使用量减少和导入路径补全。您可以在 Vetur 变更日志 中了解更多信息。

扩展开发

多扩展调试

在这个里程碑中,我们增加了同时调试多个扩展的支持。如果您正在开发一组紧密耦合或相互依赖的扩展,这将非常有用。

以前,此功能仅通过 VS Code 的命令行界面公开,现在参数 --extensionDevelopmentPath 可以多次指定。通常,--extensionDevelopmentPath 用于扩展的启动配置。当开发多个扩展时,我们建议将各个扩展项目组合到一个多文件夹工作区中,并创建一个新的启动配置(存储在工作区 .code-workspace 文件中),该配置为各个扩展使用多个 --extensionDevelopmentPath 参数。

以下是一个包含两个扩展 hello1hello2 的示例工作区 .code-workspace 文件,以及一个针对这两个扩展的单个启动配置。

{
  "folders": [{ "path": "hello1" }, { "path": "hello2" }],
  "launch": {
    "configurations": [
      {
        "type": "extensionHost",
        "request": "launch",
        "name": "Launch Two Extensions",
        "args": [
          "--extensionDevelopmentPath=${workspaceFolder:hello1}",
          "--extensionDevelopmentPath=${workspaceFolder:hello2}"
        ],
        "outFiles": [
          "${workspaceFolder:hello1}/out/**/*.js",
          "${workspaceFolder:hello2}/out/**/*.js"
        ]
      }
    ]
  }
}

请注意,在此版本中,无法通过组合各个扩展项目的 preLaunchTask 来创建同时构建两个扩展的 preLaunchTask

之前,总是可以通过语法 [链接名称](http://链接) 在通知消息中包含链接,但这仅适用于在浏览器中打开的链接。现在,您还可以通过语法 [链接名称](command:<命令 ID>) 从链接调用命令。当用户点击链接时,将触发具有所提供标识符的命令。

您现在可以为通知中的链接添加标题,当用户将鼠标悬停在链接上时会显示该标题。语法是 [链接名称](链接 "<标题>")

提议的扩展 API

每个里程碑都会带来新的提议 API,扩展作者可以尝试使用它们。一如既往,我们渴望收到您的反馈。以下是试用提议 API 的方法:

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

请注意,您不能发布使用提议 API 的扩展。我们很可能会在下一次发布中进行破坏性更改,我们绝不希望破坏现有扩展。

vscode.workspace.workspaceFile

有一个新的工作区属性,返回工作区文件的位置。例如:对于未命名且尚未保存的工作区,返回 file:///Users/name/Development/myProject.code-workspaceuntitled:1555503116870

根据打开的工作区,其值将是

  • 当没有打开工作区或单个文件夹时,为 undefined
  • 工作区文件路径的 Uri

如果工作区未命名,则返回的 URI 将使用 untitled: 方案。

工作区文件位置的一个用途是调用 vscode.openFolder 命令,以便在工作区关闭后再次打开它。

vscode.commands.executeCommand('vscode.openFolder', uriOfWorkspace);

注意: 不建议使用 workspace.workspaceFile 位置直接将配置数据写入文件。您可以使用 workspace.getConfiguration().update(),这在打开单个文件夹以及未命名或已保存的工作区时都适用。

机器特定设置

如果您有允许用户自定义可执行路径的设置,并且这些路径需要限定到它们运行的机器,那么您现在可以将此类设置归类为 machine 范围。扩展作者在贡献 configuration 扩展点时设置 scope 属性。机器特定设置只能针对用户设置进行配置。

"configuration": {
  "title": "Git",
  "properties": {
   "git.path": {
      "type": [
        "string",
        "null"
      ],
      "markdownDescription": "Path and filename of the git executable.",
      "default": null,
      "scope": "machine"
    }
  }
}

工程

重写本地文件的文件系统提供程序

扩展能够为自定义资源提供自己的文件系统实现(在此处阅读更多信息)。然而,VS Code 自身对本地文件的实现并未采用相同的扩展 API。这导致在处理本地文件资源与来自扩展的资源时存在细微差异。在过去的两个里程碑中,我们重写了我们的本地文件系统提供程序,以使用扩展 API 来保持一致性。

新文档

Python Azure Functions

有一个新的 将 Python 部署到 Azure Functions 教程,其中描述了如何创建和部署 Python 无服务器 Azure Functions。

其他

语言服务器协议

语言服务器协议 已提议支持以下新功能:

  • 选择范围:计算一组位置的选择范围。从客户端发送到服务器。
  • 调用层次结构:计算给定符号的调用层次结构。从客户端发送到服务器。
  • 进度:从服务器启动进度报告。从服务器发送到客户端。

新功能将在 vscode-languageclientvscode-languageserver npm 模块的后续版本中提供。

值得注意的修复

  • 48259: 资源管理器遵循 FileSystemProvider 的垃圾桶功能
  • 68276: “调用堆栈”中“在断点处暂停”的 UI 在线程名称过长时不可见
  • 69603: 终端窗口在 Mac OS 中崩溃
  • 72110: 调试控制台不必要地渲染换行符
  • 71737: 调试窗口中的滚动行为异常
  • 71588: 在资源管理器中显示文件时出错
  • 70492: “正在运行的扩展”上的“报告问题”按钮导致数十个重复问题

感谢

最后但同样重要的是,衷心感谢!以下帮助改进 VS Code 的各位:

对我们的问题跟踪的贡献。如果您想帮助我们管理收到的问题,请参阅我们的 社区问题跟踪 页面。

vscode 的贡献

vscode-css-languageservice 的贡献

vscode-html-languageservice 的贡献

node-jsonc-parser 的贡献

language-server-protocol 的贡献

vscode-languageserver-node 的贡献

vscode-eslint 的贡献

vscode-lsif-extension 的贡献

vscode-textmate 的贡献

vscode-recipes 的贡献

vscode-vsce 的贡献

本地化 的贡献

有超过 800 名 云 + AI 本地化 社区成员正在使用 Microsoft 本地化社区平台 (MLCP),其中约有 100 名是 Visual Studio Code 的活跃贡献者。

我们感谢您的贡献,无论是提供新翻译、对翻译进行投票还是提出流程改进建议。

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

  • 波斯尼亚语:Ismar Bašanović。
  • 捷克语:Daniel Padrta, David Jareš, Jan Hajek, Jiří Hofman。
  • 丹麦语:Allan Kimmer Jensen, Thomas Larsen。
  • 荷兰语:Maxim Van Damme, Sven Klaasen。
  • 英语(英国):Martin Littlecott, Tobias Collier, William Wood, Giorgi Jambazishvili。
  • 法语:Antoine Griffard, Thierry DEMAN-BARCELÒ, Mohamed Sahbi, Steven Dugois, Michael VAUDIN。
  • 德语:Christof Opresnik。
  • 印地语:Abhirav Kushwaha, Pramit Das。
  • 简体中文:paul cheung, 项斌, Fan Su, Justin Liu, Horie Yuan, 王文杰, 赵畅畅, anson zhang, Wang Debang, Pluwen, Yiting Zhu, Joel Yang, Michael Zhang, 钟擎, 徐涛, 谈少民, 全伟, panda small, Array Zhang, LI ZHAO。
  • 繁体中文:謝政廷, 煾雪。
  • 匈牙利语:Levente Hallai Seiler。
  • 印度尼西亚语:Laurensius Dede Suhardiman。
  • 意大利语:Alessandro Alpi, Luigi Bruno, Emanuele Meazzo, Marco Dal Pino。
  • 日语:EbXpJ6bp -, nh, Kyohei Uchida, Yoshihisa Ozaki, Seiji Momoto, Hasefumi, 熊本迪人, Koichi Makino, Kyohei Moriyama, 山本美穂, Aya Tokura。
  • 韩语:이형섭, Youngjae Kim, siin lee, Keunyop Lee。
  • 拉脱维亚语:Kaspars Bergs。
  • 立陶宛语:Augustas Grikšas。
  • 波兰语:Wojciech Maj, Marek Biedrzycki, Igor 05, Marcin Weksznejder, Szymon Seliga, Paweł Modrzejewski, ‎Michał Stojke, Artur Zdanowski。
  • 葡萄牙语(巴西):Alessandro Trovato, Judson Santiago, Roberto Fonseca, Marcelo Fernandes, Lucas Miranda, Ray Carneiro, Loiane Groner, Daniel Luna, Lucas Santos, Saymon Damásio。
  • 葡萄牙语(葡萄牙):Ana Rebelo, Pedro Teixeira, João Carvalho, Tiago Antunes。
  • 罗马尼亚语:Alexandru Staicu。
  • 俄语:Andrey Veselov, Дмитрий Кирьянов, nata kazakova, Валерий Батурин。
  • 西班牙语:Andy Gonzalez, Carlos Mendible, José María Aguilar, Alvaro Enrique Ruano。
  • 泰米尔语:Boopesh Kumar, Karunakaran Samayan, Merbin J Anselm。
  • 土耳其语:mehmetcan gun, Sinan Açar, S. Ferit Arslan。
  • 乌克兰语:Sviatoslav Ivaskiv, George Molchanyuk。
  • 越南语:Khôi Phạm, Spepirus Shouru, Việt Anh Nguyễn。