现已发布!了解 11 月份的新功能和修复。

Visual Studio Code 技巧与窍门

使用本文中的技巧和窍门,快速入门并学习如何高效使用 Visual Studio Code。熟悉强大的编辑、代码智能和源代码控制功能,并学习有用的键盘快捷键。请务必浏览入门中的其他深入主题和用户指南,以了解更多信息。

如果您刚开始使用,请务必查看VS Code 教程,其中提供了分步指南来发现关键功能。

如果您没有安装 Visual Studio Code,请转到下载页面。您可以在在 Linux 上运行 VS CodemacOSWindows 上找到特定于平台的安装说明。

喜欢观看视频?您可以观看 VS Code Day 演讲Visual Studio Code 技巧和窍门提升您的 VS Code 体验

基础知识

入门

探索 VS Code 最好的方式是打开 欢迎 页面,然后选择一个 演练,以进行 VS Code 提供的设置步骤、功能和更深入的自定义的自导式导览。当您发现和学习时,演练会跟踪您的进度。

帮助 > 欢迎 菜单打开欢迎页面,或使用命令面板中的 帮助: 欢迎 命令(⇧⌘P (Windows, Linux Ctrl+Shift+P))。

Welcome page

扩展也可以提供演练。您还可以通过使用命令面板中的 帮助: 打开演练... 命令(⇧⌘P (Windows, Linux Ctrl+Shift+P))直接打开演练。

Open walkthrough command in the Command Palette

如果您想提高代码编辑技能,请打开 交互式编辑器操场。试用 VS Code 的代码编辑功能,例如多光标编辑、IntelliSense、代码片段、Emmet 等。

帮助 > 编辑器操场 菜单打开欢迎页面,或使用命令面板中的 帮助: 交互式编辑器操场 命令(⇧⌘P (Windows, Linux Ctrl+Shift+P))。

Interactive editor playground

命令面板

访问基于当前上下文的所有可用命令。

键盘快捷键:⇧⌘P (Windows, Linux Ctrl+Shift+P)

Command Palette

默认键盘快捷键

命令面板中的许多命令都有与之关联的默认键绑定。您可以在 命令面板⇧⌘P (Windows, Linux Ctrl+Shift+P))中看到命令旁边的默认键盘快捷键。

keyboard references

键盘参考表

下载适用于您平台的键盘快捷键参考表(macOSWindowsLinux)。

Keyboard Reference Sheet

快速打开

快速搜索并打开文件。

键盘快捷键:⌘P (Windows, Linux Ctrl+P)

Quick Open

提示:键入 ? 以查看命令建议。

Quick Open command list

键入诸如 edtterm 之类的命令后跟一个空格,会显示一个下拉列表。

term command in Quick Open

在最近打开的文件之间导航

反复按下 快速打开 键盘快捷键,可在最近打开的文件之间快速循环。

从快速打开中打开多个文件

您可以通过按 右箭头快速打开 中打开多个文件。这将在后台打开当前选定的文件,您可以继续从 快速打开 中选择文件。

在最近打开的文件夹和工作区之间导航

打开最近的文件夹或工作区。

键盘快捷键:⌃R (Windows, Linux Ctrl+R)

显示一个快速选择下拉列表,其中包含来自 文件 > 打开最近 的列表,其中包含最近打开的文件夹和工作区,后跟文件。

浮动窗口

您可以在浮动窗口中打开编辑器,例如,将编辑器移动到监视器上的另一个位置,甚至是另一个监视器。

若要在浮动窗口中打开编辑器,请将其从主窗口拖出,然后将其放在当前 VS Code 窗口之外的任意位置。分离编辑器的另一种方法是右键单击编辑器选项卡,然后选择 移动到新窗口 (workbench.action.moveEditorToNewWindow) 或 复制到新窗口 选项(⌘K O (Windows, Linux Ctrl+K O))。

命令行

VS Code 具有强大的命令行界面 (CLI),可让您自定义编辑器的启动方式,以支持各种方案。例如,您可以从命令行启动 VS Code 以打开差异编辑器来比较两个文件。

请确保 VS Code 二进制文件位于您的路径中,这样您只需键入“code”即可启动 VS Code。如果 VS Code 在安装期间添加到您的环境路径,请参阅特定于平台的安装主题(在 Linux 上运行 VS CodemacOSWindows)。

# open code with current directory
code .

# open the current directory in the most recently used code window
code -r .

# create a new window
code -n

# change the language
code --locale=es

# open diff editor
code --diff <file1> <file2>

# open file at specific line and column <file:line[:character]>
code --goto package.json:10:5

# see help options
code --help

# disable all extensions
code --disable-extensions .

.vscode 文件夹

工作区特定文件位于工作区根目录下的 .vscode 文件夹中。例如,用于任务运行器tasks.json 和用于调试器launch.json

状态栏

错误和警告

键盘快捷键:⇧⌘M (Windows, Linux Ctrl+Shift+M)

快速跳转到项目中的错误和警告。

使用 F8⇧F8 (Windows, Linux Shift+F8) 循环浏览错误

errors and warnings

您可以按类型(“信息”、“错误”、“警告”)或按匹配文本过滤问题列表。

更改语言模式

状态栏中的语言模式指示与活动编辑器关联的语言(例如,Markdown、Python 等)。您可以通过选择状态栏语言模式指示器或使用键盘快捷键来更改当前编辑器的语言模式。

键盘快捷键:⌘K M (Windows, Linux Ctrl+K M)

change syntax

如果要为文件类型保留新的语言模式,请使用 配置文件关联为 命令将当前文件扩展名与已安装的语言关联。

自定义

有很多选项可以自定义 VS Code 以满足您的偏好

  • 更改您的主题
  • 更改键盘快捷方式
  • 调整您的设置
  • 添加 JSON 验证
  • 创建代码片段
  • 安装扩展

更改您的主题

VS Code 内置了许多颜色主题。使用“首选项: 颜色主题”命令或使用键盘快捷方式。

键盘快捷方式:⌘K ⌘T(Windows,Linux Ctrl+K Ctrl+T

Preview themes

您可以从 VS Code 扩展市场安装更多主题。选择“首选项: 颜色主题”>“+ 浏览其他颜色主题...”命令,从市场搜索主题。

此外,您可以安装和更改文件图标主题。

File icon themes

键位映射

您是否习惯了其他编辑器的键盘快捷方式?您可以安装一个键位映射扩展,将您喜爱的编辑器的键盘快捷方式带到 VS Code。使用“首选项:键位映射”命令,查看市场上的当前列表。以下是一些比较流行的键位映射:

自定义您的键盘快捷方式

您可以在“键盘快捷方式”编辑器中查看和自定义键盘快捷方式。使用“首选项:打开键盘快捷方式”命令或使用快捷方式打开编辑器。

键盘快捷方式:⌘K ⌘S(Windows,Linux Ctrl+K Ctrl+S

选择铅笔图标或在特定条目上使用Enter键来编辑键盘快捷方式。使用搜索字段筛选列表。

keyboard shortcuts

您也可以搜索快捷方式并将您自己的键绑定添加到 keybindings.json 文件。

customize keyboard shortcuts

有关更多信息,请参阅Visual Studio Code 的键绑定

调整您的设置

默认情况下,VS Code 会显示“设置”编辑器来查看和编辑设置。您还可以通过使用“打开用户设置 (JSON)”命令或使用 workbench.settings.editor 设置更改您的默认设置编辑器来编辑底层的 settings.json 文件。

打开用户设置 settings.json

键盘快捷方式:⌘,(Windows,Linux Ctrl+,

更改各种 UI 元素的字体大小

// Main editor
"editor.fontSize": 18,
// Terminal panel
"terminal.integrated.fontSize": 14,
// Output panel
"[Log]": {
    "editor.fontSize": 15
}

更改缩放级别

"window.zoomLevel": 5

字体连字

"editor.fontFamily": "Fira Code",
"editor.fontLigatures": true

提示:您需要安装支持字体连字的字体。FiraCode 是 VS Code 团队中使用的一种流行的字体。

font ligatures

自动保存

"files.autoSave": "afterDelay"

您也可以使用“文件”>“自动保存”从顶层菜单切换自动保存。

保存时格式化

"editor.formatOnSave": true

粘贴时格式化

"editor.formatOnPaste": true

更改制表符字符的大小

"editor.tabSize": 4

空格或制表符

"editor.insertSpaces": true

呈现空格

"editor.renderWhitespace": "all"

默认情况下,在文本选择中呈现空格字符。

忽略文件/文件夹

从您的编辑器窗口中删除这些文件/文件夹。

"files.exclude": {
    "somefolder/": true,
    "somefile": true
}

从搜索结果中删除这些文件/文件夹。

"search.exclude": {
    "someFolder/": true,
    "somefile": true
}

了解有关许多其他自定义设置的信息。

特定于语言的设置

您可以使用语言标识符来限定特定语言的设置。您可以在语言标识符参考中找到常用语言 ID 的列表。

"[languageid]": {

}

提示:您也可以使用“配置特定于语言的设置”命令创建特定于语言的设置。

language based settings

添加 JSON 验证

默认情况下,为许多文件类型启用 JSON 验证。在 settings.json 中创建您自己的架构和验证

"json.schemas": [
    {
        "fileMatch": [
            "bower.json"
        ],
        "url": "https://json.schemastore.org/bower"
    }
]

或用于在您的工作区中定义的架构

"json.schemas": [
    {
        "fileMatch": [
            "**/foo.json"
        ],
        "url": "./myschema.json"
    }
]

或使用自定义架构

"json.schemas": [
    {
        "fileMatch": [
            "/.myconfig"
        ],
        "schema": {
            "type": "object",
            "properties": {
                "name" : {
                    "type": "string",
                    "description": "The name of the entry"
                }
            }
        }
    }
]

有关更多信息,请参阅JSON文档。

配置默认浏览器

在 VS Code 中,您可以按住 Ctrl 并单击(在 macOS 上是按住 Cmd 并单击)链接,以在您的默认浏览器中打开它。您可以通过设置 workbench.externalBrowser 设置来配置默认浏览器。

将浏览器可执行文件的完整路径指定为设置值。或者,为了确保在不同设备上的正常运行,您还可以使用浏览器别名,例如 edgechromefirefox

"workbench.externalBrowser": "edge"

扩展

键盘快捷方式:⇧⌘X(Windows,Linux Ctrl+Shift+X

查找扩展

您可以使用多个来源查找扩展

  • 在 VS Code 市场中。
  • 在“扩展”视图中搜索 VS Code 内部。
  • 查看扩展推荐
  • 社区精选的扩展列表,例如awesome-vscode

在“扩展”视图中,选择“筛选器”控件,然后选择“最受欢迎”或“排序方式”>“安装计数”。

install extensions

扩展建议

在“扩展”视图中,选择“筛选器”控件,然后选择“推荐”以查看推荐的扩展列表。

show recommended extensions

创建您自己的扩展

您是否有兴趣创建自己的扩展?您可以在扩展 API 文档中了解如何执行此操作,特别是查看有关贡献点的文档

  • 配置
  • 命令
  • 键绑定
  • 语言
  • 调试器
  • 语法
  • 主题
  • 代码片段
  • jsonValidation

文件和文件夹

简单的文件对话框

使用简单的文件对话框,您可以使用 VS Code 中更简单的“快速选择”对话框替换系统默认的文件对话框,用于打开和保存文件和文件夹。

启用“简单的文件对话框”后,您可以使用 VS Code 中的“快速选择”来浏览和选择文件和文件夹。

Simple File Dialog

要启用简单的文件对话框,请配置 files.simpleDialog 设置

    "files.simpleDialog.enable": true

集成终端

键盘快捷方式:⌃`(Windows,Linux Ctrl+`

Integrated terminal

您可以从下拉列表中选择另一个终端 shell。根据您的操作系统和系统配置,您可能会看到列出不同的 shell。

进一步阅读

切换侧边栏

键盘快捷方式:⌘B(Windows,Linux Ctrl+B

toggle side bar

切换面板

键盘快捷方式:⌘J(Windows,Linux Ctrl+J

toggle panel

禅宗模式

进入无干扰的禅宗模式。

键盘快捷方式:⌘K Z(Windows,Linux Ctrl+K Z

zen mode

按两次 Esc 键退出禅宗模式。

并排编辑

键盘快捷方式:⌘\(Windows,Linux Ctrl+\

您还可以拖放编辑器以创建新的编辑器组,并在组之间移动编辑器。

split editors

在编辑器之间切换

键盘快捷方式:⌘1(Windows,Linux Ctrl+1⌘2(Windows,Linux Ctrl+2⌘3(Windows,Linux Ctrl+3

navigate editors

显示资源管理器视图

键盘快捷方式:⇧⌘E(Windows,Linux Ctrl+Shift+E

键盘快捷方式:按住 Ctrl 并单击(在 macOS 上是按住 Cmd 并单击

您可以通过将光标移动到文件链接,然后按按住 Ctrl 并单击,快速打开文件或图像,或创建新文件。

create and open file

关闭当前打开的文件夹

键盘快捷方式:⌘K F(Windows,Linux Ctrl+K F

导航历史记录

导航整个历史记录:⌃Tab(Windows,Linux Ctrl+Tab

向后导航:⌃-(Windows Alt+Left,Linux Ctrl+Alt+-

向前导航:⌃⇧-(Windows Alt+Right,Linux Ctrl+Shift+-

navigate history

文件关联

为未正确检测到的文件创建语言关联。例如,许多具有自定义文件扩展名的配置文件实际上是 JSON。

"files.associations": {
    ".database": "json"
}

防止脏写入

当您尝试保存一个无法保存的文件时,因为该文件已在磁盘上更改,VS Code 将显示一条错误消息。VS Code 会阻止保存该文件,以防止覆盖在编辑器外部所做的更改。

要解决保存冲突,请在通知弹出窗口中选择“比较”操作,以打开一个差异编辑器,该编辑器显示磁盘上文件的内容(在左侧)与 VS Code 中的内容(在右侧)进行比较

dirty write

使用编辑器工具栏中的操作来解决保存冲突。您可以“接受”您的更改,从而覆盖磁盘上的任何更改,或者“还原”到磁盘上的版本。还原意味着您的更改将丢失。

注意:在您选择两个操作之一来解决冲突之前,该文件仍保持脏状态且无法保存。

编辑技巧

以下是一些用于编辑代码的常用功能。如果您更熟悉其他编辑器的键盘快捷方式,请考虑安装一个键位映射扩展

提示:您可以通过将搜索筛选为 @recommended:keymaps,在“扩展”视图中查看推荐的键位映射扩展。

多光标选择

要在任意位置添加光标,请用鼠标选择一个位置,然后使用 Alt+单击(macOS 上为 Option+单击)。

要将光标设置在当前位置的上方或下方,请使用

键盘快捷键:⌥⌘↑(Windows Ctrl+Alt+Up,Linux Shift+Alt+Up⌥⌘↓(Windows Ctrl+Alt+Down,Linux Shift+Alt+Down

multi cursor

您可以使用 ⇧⌘L(Windows,Linux Ctrl+Shift+L 将额外的光标添加到当前选择的所有匹配项。

add cursor to all occurrences of current selection

注意:您还可以使用 editor.multiCursorModifier 设置 将修饰键更改为 Ctrl/Cmd 来应用多个光标。有关详细信息,请参阅多光标修饰键

如果您不想添加当前选择的所有匹配项,则可以使用 ⌘D(Windows,Linux Ctrl+D 代替。 这只会选择您选择的匹配项之后的下一个匹配项,因此您可以逐个添加选择。

add cursor to next occurrences of current selection one by one

列(框)选择

您可以通过在拖动鼠标时按住 Shift+Alt(macOS 上为 Shift+Option)来选择文本块。 一个单独的光标将被添加到每个选定行的末尾。

Column text selection

您还可以使用键盘快捷键来触发列选择。

垂直标尺

您可以使用 editor.rulers 设置将垂直列标尺添加到编辑器中,该设置采用您想要垂直标尺的列字符位置的数组。

{
  "editor.rulers": [20, 40, 60]
}

Editor rulers in the editor

快速滚动

按下 Alt 键可在编辑器和资源管理器中启用快速滚动。默认情况下,快速滚动使用 5 倍的速度乘数,但您可以使用 **编辑器:快速滚动灵敏度**(editor.fastScrollSensitivity)设置来控制乘数。

锁定滚动

您可以使用 **视图:切换编辑器之间的锁定滚动** 命令来同步所有可见编辑器之间的滚动。这意味着当您在一个编辑器中滚动时,所有其他编辑器都会滚动相同的量,从而使所有内容保持对齐。

Locked scrolling in the editor

您可以选择仅在按住特定键盘快捷键时才激活滚动同步。 为 workbench.action.holdLockedScrolling 命令设置键盘快捷键,以临时锁定编辑器之间的滚动。

向上/向下复制行

键盘快捷键:⇧⌥↑(Windows Shift+Alt+Up,Linux Ctrl+Shift+Alt+Up⇧⌥↓(Windows Shift+Alt+Down,Linux Ctrl+Shift+Alt+Down

由于 VS Code 的默认键盘快捷键会与 Ubuntu 键盘快捷键冲突,因此 **向上/向下复制行** 命令在 Linux 上是未绑定的,请参阅问题 #509。 您仍然可以将 editor.action.copyLinesUpActioneditor.action.copyLinesDownAction 命令设置为您自己首选的键盘快捷键。

copy line down

向上和向下移动行

键盘快捷键:⌥↑(Windows,Linux Alt+Up⌥↓(Windows,Linux Alt+Down

move line up and down

缩小/扩大选择范围

键盘快捷键:⌃⇧⌘←(Windows,Linux Shift+Alt+Left⌃⇧⌘→(Windows,Linux Shift+Alt+Right

shrink expand selection

您可以在基本编辑文档中了解更多信息。

转到文件中的符号

键盘快捷键:⇧⌘O(Windows,Linux Ctrl+Shift+O

Find by symbol

您可以通过添加冒号 @: 来按类型对符号进行分组。

group symbols by kind

转到工作区中的符号

键盘快捷键:⌘T(Windows,Linux Ctrl+T

go to symbol in workspace

大纲视图

文件资源管理器中的大纲视图(默认折叠在底部)会显示当前打开的文件的符号。

Outline view

您可以按符号名称、类别和文件中的位置进行排序,并允许快速导航到符号位置。

导航到特定行

键盘快捷键:⌃G(Windows,Linux Ctrl+G

撤消光标位置

键盘快捷键:⌘U(Windows,Linux Ctrl+U

删除尾随空格

键盘快捷键:⌘K ⌘X(Windows,Linux Ctrl+K Ctrl+X

trailing whitespace

转换文本命令

您可以使用命令面板中的 **转换** 命令将选定的文本更改为大写、小写和首字母大写。

Transform text commands

代码格式化

当前选定的源代码:⌘K ⌘F(Windows,Linux Ctrl+K Ctrl+F

整个文档格式:⇧⌥F(Windows Shift+Alt+F,Linux Ctrl+Shift+I

code formatting

代码折叠

键盘快捷键:⌥⌘[(Windows,Linux Ctrl+Shift+[⌥⌘](Windows,Linux Ctrl+Shift+]⌘K ⌘L(Windows,Linux Ctrl+K Ctrl+L

code folding

您还可以使用 **全部折叠**(⌘K ⌘0(Windows,Linux Ctrl+K Ctrl+0)和 **全部展开**(⌘K ⌘J(Windows,Linux Ctrl+K Ctrl+J)来折叠/展开编辑器中的所有区域。

您可以使用 **折叠所有块注释**(⌘K ⌘/(Windows,Linux Ctrl+K Ctrl+/)来折叠所有块注释。

选择当前行

键盘快捷键:⌘L(Windows,Linux Ctrl+L

导航到文件开头和结尾

键盘快捷键:⌘↑(Windows,Linux Ctrl+Home⌘↓(Windows,Linux Ctrl+End

打开 Markdown 预览

在 Markdown 文件中,使用

键盘快捷键:⇧⌘V(Windows,Linux Ctrl+Shift+V

Markdown preview

并排 Markdown 编辑和预览

在 Markdown 文件中,使用

键盘快捷键:⌘K V(Windows,Linux Ctrl+K V

预览和编辑器将与您在任一视图中的滚动同步。

side by side Markdown preview

IntelliSense

⌃Space(Windows,Linux Ctrl+Space 以触发建议小组件。

intellisense

您可以查看可用的方法、参数提示、简短文档等。

速览

选择一个符号,然后键入 ⌥F12(Windows Alt+F12,Linux Ctrl+Shift+F10。 或者,您可以使用上下文菜单。

peek

转到定义

选择一个符号,然后键入 F12。 或者,您可以使用上下文菜单或 Ctrl+单击(macOS 上为 Cmd+单击)。

go to definition

您可以使用 **转到** > **后退** 命令或 ⌃-(Windows Alt+Left,Linux Ctrl+Alt+- 返回到您之前的位置。

如果您在将鼠标悬停在类型上时按住 Ctrl(macOS 上为 Cmd),您也可以看到类型定义。

转到引用

选择一个符号,然后键入 ⇧F12(Windows,Linux Shift+F12。 或者,您可以使用上下文菜单。

peek references

查找所有引用视图

选择一个符号,然后键入 ⇧⌥F12(Windows,Linux Shift+Alt+F12 以打开引用视图,该视图在一个专用视图中显示您的所有文件符号。

重命名符号

选择一个符号,然后键入 F2。 或者,您可以使用上下文菜单。

rename symbol

搜索和修改

除了搜索和替换表达式,您还可以使用带有捕获组的正则表达式来搜索和重用匹配到的部分内容。通过单击使用正则表达式 .* 按钮(⌥⌘R(Windows、Linux Alt+R)在搜索框中启用正则表达式,然后编写一个正则表达式并使用括号定义组。然后,您可以在替换字段中使用 $1$2 等来重用每个组中匹配的内容。

search and modify

.eslintrc.json

安装 ESLint 扩展。按照您的喜好配置您的 linter。有关其 linting 规则和选项的详细信息,请参阅 ESLint 规范

以下是使用 ES6 的配置。

{
  "env": {
    "browser": true,
    "commonjs": true,
    "es6": true,
    "node": true
  },
  "parserOptions": {
    "ecmaVersion": 6,
    "sourceType": "module",
    "ecmaFeatures": {
      "jsx": true,
      "classes": true,
      "defaultParams": true
    }
  },
  "rules": {
    "no-const-assign": 1,
    "no-extra-semi": 0,
    "semi": 0,
    "no-fallthrough": 0,
    "no-empty": 0,
    "no-mixed-spaces-and-tabs": 0,
    "no-redeclare": 0,
    "no-this-before-super": 1,
    "no-undef": 1,
    "no-unreachable": 1,
    "no-use-before-define": 0,
    "constructor-super": 1,
    "curly": 0,
    "eqeqeq": 0,
    "func-names": 0,
    "valid-typeof": 1
  }
}

package.json

请参阅您的 package.json 文件的 IntelliSense。

package json intellisense

Emmet 语法

支持 Emmet 语法.

emmet syntax

代码片段

创建自定义代码片段

文件 > 首选项 > 配置用户代码片段,选择语言,然后创建一个代码片段。

"create component": {
    "prefix": "component",
    "body": [
        "class $1 extends React.Component {",
        "",
        "\trender() {",
        "\t\treturn ($2);",
        "\t}",
        "",
        "}"
    ]
},

有关更多详细信息,请参阅创建您自己的代码片段

Git 集成

键盘快捷键:⌃⇧G(Windows、Linux Ctrl+Shift+G

VS Code “开箱即用”地集成了 Git。您可以从 VS Code 扩展市场 安装其他源代码管理 (SCM) 提供程序。本节介绍 Git 集成,但许多 UI 和手势对于其他 SCM 提供程序是通用的。

差异

源代码管理视图中,选择一个文件以打开差异编辑器。或者,选择右上角的打开更改按钮以比较当前打开文件的差异。

git diff from source control

视图

差异的默认视图是并排视图

通过选择右上角的更多操作 (...) 按钮,然后选择内联视图来切换内联视图

Screenshot that shows the More Actions menu in the diff editor, highlighting the Inline View menu item

如果您更喜欢将内联视图作为默认视图,请配置 "diffEditor.renderSideBySide": false 设置。

可访问的差异查看器

使用 F7⇧F7(Windows、Linux Shift+F7 浏览差异。这会以统一补丁格式呈现更改。可以使用箭头键导航行,按 Enter 键会跳转回差异编辑器和所选行。

diff_review_pane

编辑待处理的更改

当您在差异编辑器中查看更改时,您可以直接在差异编辑器的待处理更改侧进行编辑。

分支

通过状态栏轻松切换 Git 分支。

switch branches

暂存

暂存文件更改

将鼠标悬停在文件数上,然后选择加号按钮以暂存文件。

选择减号按钮以取消暂存更改。

git stage all

暂存所选内容

您可以通过在文件中进行文本选择,然后从命令面板或差异编辑器上下文菜单(右键单击)中选择暂存所选范围来暂存文件的部分内容。

撤消上次提交

选择 (...) 按钮,然后选择提交 > 撤消上次提交以撤消上次提交。更改将添加到“暂存的更改”部分。

undo last commit

查看 Git 输出

VS Code 可以轻松查看实际运行的 Git 命令。当您仍在学习 Git 或调试困难的源代码管理问题时,这可能会有所帮助。

要查看 Git 输出,请在源代码管理视图中选择 (...) 按钮,然后选择显示 Git 输出,使用 Git: 显示 Git 输出 命令,或使用切换输出命令(⇧⌘U(Windows Ctrl+Shift+U,Linux Ctrl+K Ctrl+H),然后从下拉列表中选择 Git

装订线指示器

编辑器在装订线中提供了有关在何处以及进行了哪些更改(添加、更改或删除行)的可视提示。有关更多详细信息,请参阅源代码管理文档

git gutter indicators

解决合并冲突

在合并期间,转到源代码管理视图(⌃⇧G(Windows、Linux Ctrl+Shift+G),并在差异视图中进行更改。

您可以使用内联 CodeLens 解决合并冲突,它允许您接受当前更改接受传入更改接受两个更改比较更改

Git merge

在源代码管理文档中了解有关解决合并冲突的更多信息。

将 VS Code 设置为默认合并工具

git config --global merge.tool vscode
git config --global mergetool.vscode.cmd 'code --wait $MERGED'

将 VS Code 设置为默认差异工具

git config --global diff.tool vscode
git config --global difftool.vscode.cmd 'code --wait --diff $LOCAL $REMOTE'

将文件与剪贴板进行比较

键盘快捷键:⌘K C(Windows、Linux Ctrl+K C

使用命令面板(⇧⌘P(Windows、Linux Ctrl+Shift+P)中的 文件:将活动文件与剪贴板进行比较 命令,快速将活动文件与剪贴板的内容进行比较。

调试

配置调试器

从运行和调试视图(⇧⌘D(Windows、Linux Ctrl+Shift+D)中,选择创建 launch.json 文件,它会提示您选择与您的项目匹配的环境(Node.js、Python、C++ 等)。这会在您的工作区中生成一个 launch.json 文件,其中包含调试器配置。

Node.js 支持是内置的,其他环境需要安装适当的语言扩展。有关更多详细信息,请参阅调试文档

configure debugging

断点和单步调试

通过选择编辑器边距或在当前行使用 F9 来切换断点。编辑器边距中的断点通常显示为红色实心圆圈。

一旦调试会话开始,调试工具栏会出现在编辑器的顶部,并允许您在调试时单步执行或进入代码。在调试文档中了解有关调试操作的更多信息。

debug

数据检查

可以在运行和调试视图的变量部分中,通过将鼠标悬停在编辑器中的源代码上或使用调试控制台来检查变量。

data inspection

日志点

日志点的作用类似于断点,但是当它们被命中时,它们会将消息记录到控制台,而不是停止调试器。日志点对于在调试无法修改或暂停的生产服务器时注入日志记录特别有用。

在左侧编辑器装订线中使用添加日志点命令添加日志点,它将显示为“菱形”形状的图标。日志消息是纯文本,但可以包含在花括号 ('{}') 中计算的表达式。

Logpoint set in the editor

触发的断点

触发的断点是另一个断点被命中后自动启用的断点。当诊断仅在特定前提条件之后发生的代码中的故障案例时,它们非常有用。

可以通过右键单击字形边距,选择添加触发的断点,然后选择哪个其他断点启用断点来设置触发的断点。

任务运行器

可以配置 VS Code 中的任务来运行脚本和启动进程,以便这些工具可以在 VS Code 中使用,而无需输入命令行或编写新代码。

自动检测任务

从顶部菜单中选择终端,运行命令配置任务,然后选择您要运行的任务类型。这将生成一个类似于以下内容的 tasks.json 文件。有关更多详细信息,请参阅任务文档。

{
  // See https://go.microsoft.com/fwlink/?LinkId=733558
  // for the documentation about the tasks.json format
  "version": "2.0.0",
  "tasks": [
    {
      "type": "npm",
      "script": "install",
      "group": {
        "kind": "build",
        "isDefault": true
      }
    }
  ]
}

有时自动生成会出现问题。请查看文档以了解如何正确运行。

从终端菜单运行任务

从顶部菜单中选择终端,运行命令运行任务,然后选择要运行的任务。通过运行命令终止任务来终止正在运行的任务。

task runner

为任务定义键盘快捷键

您可以为任何任务定义键盘快捷键。从命令面板⇧⌘P(Windows、Linux Ctrl+Shift+P)中,选择首选项:打开键盘快捷键文件,将所需的快捷方式绑定到 workbench.action.tasks.runTask 命令,并将任务定义为 args

例如,要将 Ctrl+H 绑定到 Run tests 任务,请添加以下内容

{
  "key": "ctrl+h",
  "command": "workbench.action.tasks.runTask",
  "args": "Run tests"
}

从资源管理器中将 npm 脚本作为任务运行

从资源管理器视图中,您可以在编辑器中打开脚本,将其作为任务运行,并使用 node 调试器启动它(当脚本定义了诸如 --inspect-brk 之类的调试选项时)。单击的默认操作是打开脚本。要在单击时运行脚本,请将 npm.scriptExplorerAction 设置为 run。使用设置 npm.exclude 排除特定文件夹中包含的 package.json 文件中的脚本。

Filter problems

使用设置 npm.enableRunFromFolder,您可以启用从资源管理器视图上下文菜单为文件夹运行 npm 脚本。该设置在选择文件夹时启用命令在文件夹中运行 NPM 脚本...。该命令显示此文件夹中包含的 npm 脚本的快速选择列表,您可以选择要作为任务执行的脚本。

便携模式

VS Code 具有便携模式,该模式允许您将设置和数据保存在与安装相同的位置,例如,在 USB 驱动器上。

内部版本

Visual Studio Code 团队使用 Insiders 版本来测试 VS Code 的最新功能和错误修复。您还可以通过在此处下载来使用 Insiders 版本。

  • 对于早期采用者 - Insiders 拥有用户和扩展作者可以尝试的最新代码更改。
  • 频繁构建 - 每天都有包含最新错误修复和功能的新版本。
  • 并行安装 - 预览体验成员版本与稳定版本并行安装,允许您独立使用其中任何一个版本。