0% found this document useful (0 votes)
208 views15 pages

Visual Studio Code Keyboard Shortcuts Guide

The document provides an overview of key bindings in Visual Studio Code, detailing how to access, customize, and troubleshoot keyboard shortcuts. It includes information on platform-specific bindings, keymap extensions, and the Keyboard Shortcuts editor for managing keybindings. Additionally, it discusses advanced customization options and how to detect keybinding conflicts.

Uploaded by

racamesavisam
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
208 views15 pages

Visual Studio Code Keyboard Shortcuts Guide

The document provides an overview of key bindings in Visual Studio Code, detailing how to access, customize, and troubleshoot keyboard shortcuts. It includes information on platform-specific bindings, keymap extensions, and the Keyboard Shortcuts editor for managing keybindings. Additionally, it discusses advanced customization options and how to detect keybinding conflicts.

Uploaded by

racamesavisam
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd

22/5/23, 8:01 Visual Studio Code Key Bindings

Version 1.78 (/updates) is now available! Read about the new features and fixes from April. ×

Topics Key Bindings

✏ ([Link]
Key Bindings for Visual Studio Code
Visual Studio Code lets you perform most tasks directly from the keyboard. This page lists out the default bindings (keyboard shortcuts) and describes how you can
update them.

Note: If you visit this page on a Mac, you will see the key bindings for the Mac. If you visit using Windows or Linux, you will see the keys for that platform. If you need
the key bindings for another platform, hover your mouse over the key you are interested in.

Keyboard Shortcuts editor


Visual Studio Code provides a rich and easy keyboard shortcuts editing experience using Keyboard Shortcuts editor. It lists all available commands with and without
keybindings and you can easily change / remove / reset their keybindings using the available actions. It also has a search box on the top that helps you in finding
commands or keybindings. You can open this editor by going to the menu under File > Preferences > Keyboard Shortcuts. (Code > Preferences > Keyboard Shortcuts
on macOS)

Most importantly, you can see keybindings according to your keyboard layout. For example, key binding Cmd+\ in US keyboard layout will be shown as
Ctrl+Shift+Alt+Cmd+7 when layout is changed to German. The dialog to enter key binding will assign the correct and desired key binding as per your keyboard layout.

For doing more advanced keyboard shortcut customization, read Advanced Customization (/docs/getstarted/keybindings#_advanced-customization).

Keymap extensions
Keyboard shortcuts are vital to productivity and changing keyboarding habits can be tough. To help with this, File > Preferences > Migrate Keyboard Shortcuts from...
shows you a list of popular keymap extensions. These extensions modify the VS Code shortcuts to match those of other editors so you don't need to learn new keyboard
shortcuts. There is also a Keymaps category ([Link] of extensions in the
Marketplace.

[Link] 1/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Vim Sublime Text Keymap and Settings Imp… Atom Keymap Brackets Keymap
vscodevim 5.0M ms-vscode 1.9M ms-vscode 966.7K ms-vscode 140.1K

([Link] ([Link] ([Link] ([Link]


ems?itemName=[Link]) ems?itemName=[Link]- ems?itemName=[Link]- ems?itemName=[Link]-
keybindings) keybindings) keybindings)

Tip: Click on an extension tile above to read the description and reviews to decide which extension is best for you. See more in the Marketplace
([Link]

Keyboard Shortcuts Reference


We also have a printable version of these keyboard shortcuts. Help > Keyboard Shortcut Reference displays a condensed PDF version suitable for printing as an easy
reference.

Below are links to the three platform-specific versions (US English keyboard):

Windows ([Link]
macOS ([Link]
Linux ([Link]

Detecting keybinding conflicts


If you have many extensions installed or you have customized (/docs/getstarted/keybindings#_advanced-customization) your keyboard shortcuts, you can sometimes
have keybinding conflicts where the same keyboard shortcut is mapped to several commands. This can result in confusing behavior, especially if different keybindings are
going in and out of scope as you move around the editor.

The Keyboard Shortcuts editor has a context menu command Show Same Keybindings, which will filter the keybindings based on a keyboard shortcut to display
conflicts.

Pick a command with the keybinding you think is overloaded and you can see if multiple commands are defined, the source of the keybindings and when they are active.

[Link] 2/15
22/5/23, 8:01 Visual Studio Code Key Bindings
Troubleshooting keybindings
To troubleshoot keybindings problems, you can execute the command Developer: Toggle Keyboard Shortcuts Troubleshooting. This will activate logging of dispatched
keyboard shortcuts and will open an output panel with the corresponding log file.

You can then press your desired keybinding and check what keyboard shortcut VS Code detects and what command is invoked.

For example, when pressing cmd+/ in a code editor on macOS, the logging output would be:

[KeybindingService]: / Received keydown event - modifiers: [meta], code: MetaLeft, keyCode: 91, key: Meta
[KeybindingService]: | Converted keydown event - modifiers: [meta], code: MetaLeft, keyCode: 57 ('Meta')
[KeybindingService]: \ Keyboard event cannot be dispatched.
[KeybindingService]: / Received keydown event - modifiers: [meta], code: Slash, keyCode: 191, key: /
[KeybindingService]: | Converted keydown event - modifiers: [meta], code: Slash, keyCode: 85 ('/')
[KeybindingService]: | Resolving meta+[Slash]
[KeybindingService]: \ From 2 keybinding entries, matched [Link], when: editorTextFocus && !editorReadonly, source: built-i
n.

The first keydown event is for the MetaLeft key ( cmd ) and cannot be dispatched. The second keydown event is for the Slash key ( / ) and is dispatched as meta+
[Slash] . There were two keybinding entries mapped from meta+[Slash] and the one that matched was for the command [Link] , which has the
when condition editorTextFocus && !editorReadonly and is a built-in keybinding entry.

Viewing modified keybindings


You can view any user modified keyboard shortcuts in VS Code in the Keyboard Shortcuts editor with the Show User Keybindings command in the More Actions (...)
menu. This applies the @source:user filter to the Keyboard Shortcuts editor (Source is 'User').

Advanced customization
All keyboard shortcuts in VS Code can be customized via the [Link] file.

To configure keyboard shortcuts through the JSON file, open Keyboard Shortcuts editor and select the Open Keyboard Shortcuts (JSON) button on the right of
the editor title bar.
This will open your [Link] file where you can overwrite the Default Keyboard Shortcuts (/docs/getstarted/keybindings#_default-keyboard-shortcuts).

You can also open the [Link] file from the Command Palette ( Ctrl+Shift+P ) with the Preferences: Open Keyboard Shortcuts (JSON) command.

Keyboard rules
Each rule consists of:

a key that describes the pressed keys.


a command containing the identifier of the command to execute.
an optional when clause containing a boolean expression that will be evaluated depending on the current context.

Chords (two separate keypress actions) are described by separating the two keypresses with a space. For example, Ctrl+K Ctrl+C .

When a key is pressed:

the rules are evaluated from bottom to top.


the first rule that matches, both the key and in terms of when , is accepted.
no more rules are processed.

[Link] 3/15
22/5/23, 8:01 Visual Studio Code Key Bindings
if a rule is found and has a command set, the command is executed.

The additional [Link] rules are appended at runtime to the bottom of the default rules, thus allowing them to overwrite the default rules. The
[Link] file is watched by VS Code so editing it while VS Code is running will update the rules at runtime.

The keyboard shortcuts dispatching is done by analyzing a list of rules that are expressed in JSON. Here are some examples:

// Keybindings that are active when the focus is in the editor


{ "key": "home", "command": "cursorHome", "when": "editorTextFocus" },
{ "key": "shift+home", "command": "cursorHomeSelect", "when": "editorTextFocus" },

// Keybindings that are complementary


{ "key": "f5", "command": "[Link]", "when": "inDebugMode" },
{ "key": "f5", "command": "[Link]", "when": "!inDebugMode" },

// Global keybindings
{ "key": "ctrl+f", "command": "[Link]" },
{ "key": "alt+left", "command": "[Link]" },
{ "key": "alt+right", "command": "[Link]" },

// Global keybindings using chords (two separate keypress actions)


{ "key": "ctrl+k enter", "command": "[Link]" },
{ "key": "ctrl+k ctrl+w", "command": "[Link]" },

Accepted keys
The key is made up of modifiers and the key itself.

The following modifiers are accepted:

Platform Modifiers

macOS Ctrl+ , Shift+ , Alt+ , Cmd+

Windows Ctrl+ , Shift+ , Alt+ , Win+

Linux Ctrl+ , Shift+ , Alt+ , Meta+

The following keys are accepted:

f1-f19 , a-z , 0-9


`, -, =, [, ], \, ;, ', ,, ., /
left , up , right , down , pageup , pagedown , end , home
tab , enter , escape , space , backspace , delete
pausebreak , capslock , insert
numpad0-numpad9 , numpad_multiply , numpad_add , numpad_separator
numpad_subtract , numpad_decimal , numpad_divide

Command arguments
You can invoke a command with arguments. This is useful if you often perform the same operation on a specific file or folder. You can add a custom keyboard shortcut to
do exactly what you want.

The following is an example overriding the Enter key to print some text:

{
"key": "enter",
"command": "type",
"args": { "text": "Hello World" },
"when": "editorTextFocus"
}

The type command will receive {"text": "Hello World"} as its first argument and add "Hello World" to the file instead of producing the default command.

For more information on commands that take arguments, refer to Built-in Commands (/api/references/commands).

Running multiple commands


It is possible to create a keybinding that runs several other commands sequentially using the command runCommands .

1. Run several commands without arguments: copy current line down, mark the current line as comment, move cursor to copied line

[Link] 4/15
22/5/23, 8:01 Visual Studio Code Key Bindings

{
"key": "ctrl+alt+c",
"command": "runCommands",
"args": {
"commands": [
"[Link]",
"cursorUp",
"[Link]",
"cursorDown"
]
}
},

2. It is also possible to pass arguments to commands: create a new untitled TypeScript file and insert a custom snippet

{
"key": "ctrl+n",
"command": "runCommands",
"args": {
"commands": [
{
"command": "[Link]",
"args": {
"languageId": "typescript"
}
},
{
"command": "[Link]",
"args": {
"langId": "typescript",
"snippet": "class ${1:ClassName} {\n\tconstructor() {\n\t\t$0\n\t}\n}"
}
}
]
}
},

Note that commands run by runCommands receive the value of "args" as the first argument. So in the example above, [Link]
receives {"languageId": "typescript" } as its first and only argument.

To pass several arguments, one needs to have "args" as an array:

{
"key": "ctrl+shift+e",
"command": "runCommands",
"args": {
"commands": [
{
// command invoked with 2 arguments: [Link]("myCommand", "arg1", "arg2")
"command": "myCommand",
"args": ["arg1", "arg2"]
}
]
}
}

To pass an array as the first argument, one needs to wrap the array in another array: "args": [ [1, 2, 3] ] .

Removing a specific key binding rule


You can write a key binding rule that targets the removal of a specific default key binding. With the [Link] , it was always possible to redefine all the key
bindings of VS Code, but it can be difficult to make a small tweak, especially around overloaded keys, such as Tab or Escape . To remove a specific key binding, add a -
to the command and the rule will be a removal rule.

Here is an example:

// In Default Keyboard Shortcuts


...
{ "key": "tab", "command": "tab", "when": ... },
{ "key": "tab", "command": "jumpToNextSnippetPlaceholder", "when": ... },
{ "key": "tab", "command": "acceptSelectedSuggestion", "when": ... },
...

// To remove the second rule, for example, add in [Link]:


{ "key": "tab", "command": "-jumpToNextSnippetPlaceholder" }

To override a specific key binding rule with an empty action, you can specify an empty command:

[Link] 5/15
22/5/23, 8:01 Visual Studio Code Key Bindings

// To override and disable any `tab` keybinding, for example, add in [Link]:
{ "key": "tab", "command": "" }

Keyboard layouts

Note: This section relates only to key bindings, not to typing in the editor.

The keys above are string representations for virtual keys and do not necessarily relate to the produced character when they are pressed. More precisely:

Reference: Virtual-Key Codes (Windows) ([Link]


tab for VK_TAB ( 0x09 )
; for VK_OEM_1 ( 0xBA )
= for VK_OEM_PLUS ( 0xBB )
, for VK_OEM_COMMA ( 0xBC )
- for VK_OEM_MINUS ( 0xBD )
. for VK_OEM_PERIOD ( 0xBE )
/ for VK_OEM_2 ( 0xBF )
` for VK_OEM_3 ( 0xC0 )
[ for VK_OEM_4 ( 0xDB )
\ for VK_OEM_5 ( 0xDC )
] for VK_OEM_6 ( 0xDD )
' for VK_OEM_7 ( 0xDE )
etc.

Different keyboard layouts usually reposition the above virtual keys or change the characters produced when they are pressed. When using a different keyboard layout
than the standard US, Visual Studio Code does the following:

All the key bindings are rendered in the UI using the current system's keyboard layout. For example, Split Editor when using a French (France) keyboard layout is now
rendered as Ctrl+* :

When editing [Link] , VS Code highlights misleading key bindings, those that are represented in the file with the character produced under the standard US
keyboard layout, but that need pressing keys with different labels under the current system's keyboard layout. For example, here is how the Default Keyboard Shortcuts
rules look like when using a French (France) keyboard layout:

[Link] 6/15
22/5/23, 8:01 Visual Studio Code Key Bindings

There is also a widget that helps input the key binding rule when editing [Link] . To launch the Define Keybinding widget, press Ctrl+K Ctrl+K . The widget
listens for key presses and renders the serialized JSON representation in the text box and below it, the keys that VS Code has detected under your current keyboard
layout. Once you've typed the key combination you want, you can press Enter and a rule snippet will be inserted.

Note: On Linux, Visual Studio Code detects your current keyboard layout on start-up and then caches this information. For a good experience, we recommend
restarting VS Code if you change your keyboard layout.

Keyboard layout-independent bindings


Using scan codes, it is possible to define keybindings which do not change with the change of the keyboard layout. For example:

{ "key": "cmd+[Slash]", "command": "[Link]", "when": "editorTextFocus" }

Accepted scan codes:

[F1]-[F19] , [KeyA]-[KeyZ] , [Digit0]-[Digit9]


[Backquote] , [Minus] , [Equal] , [BracketLeft] , [BracketRight] , [Backslash] , [Semicolon] , [Quote] , [Comma] , [Period] , [Slash]
[ArrowLeft] , [ArrowUp] , [ArrowRight] , [ArrowDown] , [PageUp] , [PageDown] , [End] , [Home]
[Tab] , [Enter] , [Escape] , [Space] , [Backspace] , [Delete]
[Pause] , [CapsLock] , [Insert]
[Numpad0]-[Numpad9] , [NumpadMultiply] , [NumpadAdd] , [NumpadComma]
[NumpadSubtract] , [NumpadDecimal] , [NumpadDivide]

when clause contexts


VS Code gives you fine control over when your key bindings are enabled through the optional when clause. If your key binding doesn't have a when clause, the key
binding is globally available at all times. A when clause evaluates to either Boolean true or false for enabling key bindings.

VS Code sets various context keys and specific values depending on what elements are visible and active in the VS Code UI. For example, the built-in Start Debugging
command has the keyboard shortcut F5 , which is only enabled when there is an appropriate debugger available (context debuggersAvailable is true) and the editor
isn't in debug mode (context inDebugMode is false):

[Link] 7/15
22/5/23, 8:01 Visual Studio Code Key Bindings

You can also view a keybinding's when clause directly in the Default Keybindings JSON (Preferences: Open Default Keyboard Shortcuts (JSON)):

{ "key": "f5", "command": "[Link]",


"when": "debuggersAvailable && !inDebugMode" },

Conditional operators
For when clause conditional expressions, the following conditional operators are useful for keybindings:

Operator Symbol Example

Equality == "editorLangId == typescript"

Inequality != "resourceExtname != .js"

Or || "isLinux || isWindows"

And && "textInputFocus && !editorReadonly"

Matches =~ "resourceScheme =~ /^untitled$|^file$/"

You can find the full list of when clause conditional operators in the when clause contexts (/api/references/when-clause-contexts#_conditional-operators) reference.

Available contexts
You can find some of the available when clause contexts in the when clause context reference (/api/references/when-clause-contexts).

The list there isn't exhaustive and you can find other when clause contexts by searching and filtering in the Keyboard Shortcuts editor (Preferences: Open Keyboard
Shortcuts ) or reviewing the Default Keybindings JSON file (Preferences: Open Default Keyboard Shortcuts (JSON)).

Custom keybindings for refactorings


The [Link] command lets you configure keybindings for specific Refactorings (/docs/editor/refactoring) (Code Actions). For example, the
keybinding below triggers the Extract function refactoring Code Actions:

{
"key": "ctrl+shift+r ctrl+e",
"command": "[Link]",
"args": {
"kind": "[Link]"
}
}

This is covered in depth in the Refactoring (/docs/editor/refactoring#_keybindings-for-code-actions) topic where you can learn about different kinds of Code Actions and
how to prioritize them in the case of multiple possible refactorings.

Default Keyboard Shortcuts


You can view all default keyboard shortcuts in VS Code in the Keyboard Shortcuts editor with the Show Default Keybindings command in the More Actions (...) menu.
This applies the @source:default filter to the Keyboard Shortcuts editor (Source is 'Default').

[Link] 8/15
22/5/23, 8:01 Visual Studio Code Key Bindings

You can view the default keyboard shortcuts as a JSON file using the command Preferences: Open Default Keyboard Shortcuts (JSON).

Note: The following keys are rendered assuming a standard US keyboard layout. If you use a different keyboard layout, please read below
(/docs/getstarted/keybindings#_keyboard-layouts). You can view the currently active keyboard shortcuts in VS Code in the Command Palette (View -> Command
Palette) or in the Keyboard Shortcuts editor (File > Preferences > Keyboard Shortcuts).

Some commands included below do not have default keyboard shortcuts and so are displayed as unassigned but you can assign your own keybindings.

Basic Editing

Command Key Command id

Cut line (empty selection) Ctrl+X [Link]

Copy line (empty selection) Ctrl+C [Link]

Paste Ctrl+V [Link]

Delete Line Ctrl+Shift+K [Link]

Insert Line Below Ctrl+Enter [Link]

Insert Line Above Ctrl+Shift+Enter [Link]

Move Line Down Alt+Down [Link]

Move Line Up Alt+Up [Link]

Copy Line Down Shift+Alt+Down [Link]

Copy Line Up Shift+Alt+Up [Link]

Undo Ctrl+Z undo

Redo Ctrl+Y redo

Add Selection To Next Find Match Ctrl+D [Link]

Move Last Selection To Next Find Match Ctrl+K Ctrl+D [Link]

Undo last cursor operation Ctrl+U cursorUndo

Insert cursor at end of each line selected Shift+Alt+I [Link]

Select all occurrences of current selection Ctrl+Shift+L [Link]

Select all occurrences of current word Ctrl+F2 [Link]

Select current line Ctrl+L expandLineSelection

Insert Cursor Below Ctrl+Alt+Down [Link]

Insert Cursor Above Ctrl+Alt+Up [Link]

Jump to matching bracket Ctrl+Shift+\ [Link]

Indent Line Ctrl+] [Link]

Outdent Line Ctrl+[ [Link]

Go to Beginning of Line Home cursorHome

Go to End of Line End cursorEnd

Go to End of File Ctrl+End cursorBottom

[Link] 9/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Command Key Command id

Go to Beginning of File Ctrl+Home cursorTop

Scroll Line Down Ctrl+Down scrollLineDown

Scroll Line Up Ctrl+Up scrollLineUp

Scroll Page Down Alt+PageDown scrollPageDown

Scroll Page Up Alt+PageUp scrollPageUp

Fold (collapse) region Ctrl+Shift+[ [Link]

Unfold (uncollapse) region Ctrl+Shift+] [Link]

Fold (collapse) all subregions Ctrl+K Ctrl+[ [Link]

Unfold (uncollapse) all subregions Ctrl+K Ctrl+] [Link]

Fold (collapse) all regions Ctrl+K Ctrl+0 [Link]

Unfold (uncollapse) all regions Ctrl+K Ctrl+J [Link]

Add Line Comment Ctrl+K Ctrl+C [Link]

Remove Line Comment Ctrl+K Ctrl+U [Link]

Toggle Line Comment Ctrl+/ [Link]

Toggle Block Comment Shift+Alt+A [Link]

Find Ctrl+F [Link]

Replace Ctrl+H [Link]

Find Next Enter [Link]

Find Previous Shift+Enter [Link]

Select All Occurrences of Find Match Alt+Enter [Link]

Toggle Find Case Sensitive Alt+C toggleFindCaseSensitive

Toggle Find Regex Alt+R toggleFindRegex

Toggle Find Whole Word Alt+W toggleFindWholeWord

Toggle Use of Tab Key for Setting Focus Ctrl+M [Link]

Toggle Render Whitespace unassigned toggleRenderWhitespace

Toggle Word Wrap Alt+Z [Link]

Rich Languages Editing

Command Key Command id

Trigger Suggest Ctrl+Space [Link]

Trigger Parameter Hints Ctrl+Shift+Space [Link]

Format Document Shift+Alt+F [Link]

Format Selection Ctrl+K Ctrl+F [Link]

Go to Definition F12 [Link]

Show Hover Ctrl+K Ctrl+I [Link]

Peek Definition Alt+F12 [Link]

Open Definition to the Side Ctrl+K F12 [Link]

Quick Fix Ctrl+. [Link]

Go to References Shift+F12 [Link]

Rename Symbol F2 [Link]

Replace with Next Value Ctrl+Shift+. [Link]

[Link] 10/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Command Key Command id

Replace with Previous Value Ctrl+Shift+, [Link]

Expand AST Selection Shift+Alt+Right [Link]

Shrink AST Selection Shift+Alt+Left [Link]

Trim Trailing Whitespace Ctrl+K Ctrl+X [Link]

Change Language Mode Ctrl+K M [Link]

Navigation

Command Key Command id

Show All Symbols Ctrl+T [Link]

Go to Line... Ctrl+G [Link]

Go to File..., Quick Open Ctrl+P [Link]

Go to Symbol... Ctrl+Shift+O [Link]

Show Problems Ctrl+Shift+M [Link]

Go to Next Error or Warning F8 [Link]

Go to Previous Error or Warning Shift+F8 [Link]

Show All Commands Ctrl+Shift+P or F1 [Link]

Navigate Editor Group History Ctrl+Tab [Link]

Go Back Alt+Left [Link]

Go back in Quick Input Alt+Left [Link]

Go Forward Alt+Right [Link]

Focus Breadcrumbs Ctrl+Shift+; [Link]

Focus and Select Breadcrumbs Ctrl+Shift+. [Link]

Editor/Window Management

Command Key Command id

New Window Ctrl+Shift+N [Link]

Close Window Alt+F4 [Link]

Close Editor Ctrl+W [Link]

Close Folder Ctrl+K F [Link]

Cycle Between Editor Groups unassigned [Link]

Split Editor Ctrl+\ [Link]

Focus into First Editor Group Ctrl+1 [Link]

Focus into Second Editor Group Ctrl+2 [Link]

Focus into Third Editor Group Ctrl+3 [Link]

Focus into Editor Group on the Left unassigned [Link]

Focus into Editor Group on the Right unassigned [Link]

Move Editor Left Ctrl+Shift+PageUp [Link]

Move Editor Right Ctrl+Shift+PageDown [Link]

Move Active Editor Group Left Ctrl+K Left [Link]

Move Active Editor Group Right Ctrl+K Right [Link]

Move Editor into Next Group Ctrl+Alt+Right [Link]

[Link] 11/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Command Key Command id

Move Editor into Previous Group Ctrl+Alt+Left [Link]

File Management

Command Key Command id

New File Ctrl+N [Link]

Open File... Ctrl+O [Link]

Save Ctrl+S [Link]

Save All Ctrl+K S saveAll

Save As... Ctrl+Shift+S [Link]

Close Ctrl+W [Link]

Close Others unassigned [Link]

Close Group Ctrl+K W [Link]

Close Other Groups unassigned [Link]

Close Group to Left unassigned [Link]

Close Group to Right unassigned [Link]

Close All Ctrl+K Ctrl+W [Link]

Reopen Closed Editor Ctrl+Shift+T [Link]

Keep Open Ctrl+K Enter [Link]

Copy Path of Active File Ctrl+K P [Link]

Reveal Active File in Windows Ctrl+K R [Link]

Show Opened File in New Window Ctrl+K O [Link]

Compare Opened File With unassigned [Link]

Display

Command Key Command id

Toggle Full Screen F11 [Link]

Toggle Zen Mode Ctrl+K Z [Link]

Leave Zen Mode Escape Escape [Link]

Zoom in Ctrl+= [Link]

Zoom out Ctrl+- [Link]

Reset Zoom Ctrl+Numpad0 [Link]

Toggle Sidebar Visibility Ctrl+B [Link]

Show Explorer / Toggle Focus Ctrl+Shift+E [Link]

Show Search Ctrl+Shift+F [Link]

Show Source Control Ctrl+Shift+G [Link]

Show Run Ctrl+Shift+D [Link]

Show Extensions Ctrl+Shift+X [Link]

Show Output Ctrl+Shift+U [Link]

Quick Open View Ctrl+Q [Link]

Open New Command Prompt Ctrl+Shift+C [Link]

Toggle Markdown Preview Ctrl+Shift+V [Link]

[Link] 12/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Command Key Command id

Open Preview to the Side Ctrl+K V [Link]

Toggle Integrated Terminal Ctrl+` [Link]

Search

Command Key Command id

Show Search Ctrl+Shift+F [Link]

Replace in Files Ctrl+Shift+H [Link]

Toggle Match Case Alt+C toggleSearchCaseSensitive

Toggle Match Whole Word Alt+W toggleSearchWholeWord

Toggle Use Regular Expression Alt+R toggleSearchRegex

Toggle Search Details Ctrl+Shift+J [Link]

Focus Next Search Result F4 [Link]

Focus Previous Search Result Shift+F4 [Link]

Show Next Search Term Down [Link]

Show Previous Search Term Up [Link]

Search Editor

Command Key Command id

Open Results In Editor Alt+Enter [Link]

Focus Search Editor Input Escape [Link]

Search Again Ctrl+Shift+R rerunSearchEditorSearch

Delete File Results Ctrl+Shift+Backspace [Link]

Preferences

Command Key Command id

Open Settings Ctrl+, [Link]

Open Workspace Settings unassigned [Link]

Open Keyboard Shortcuts Ctrl+K Ctrl+S [Link]

Open User Snippets unassigned [Link]

Select Color Theme Ctrl+K Ctrl+T [Link]

Configure Display Language unassigned [Link]

Debug

Command Key Command id

Toggle Breakpoint F9 [Link]

Start F5 [Link]

Continue F5 [Link]

Start (without debugging) Ctrl+F5 [Link]

Pause F6 [Link]

Step Into F11 [Link]

[Link] 13/15
22/5/23, 8:01 Visual Studio Code Key Bindings
Tasks

Command Key Command id

Run Build Task Ctrl+Shift+B [Link]

Run Test Task unassigned [Link]

Extensions

Command Key Command id

Install Extension unassigned [Link]

Show Installed Extensions unassigned [Link]

Show Outdated Extensions unassigned [Link]

Show Recommended Extensions unassigned [Link]

Show Popular Extensions unassigned [Link]

Update All Extensions unassigned [Link]

Next steps
Now that you know about our Key binding support, what's next...

Language Support (/docs/languages/overview) - Our Good, Better, Best language grid to see what you can expect
Debugging (/docs/editor/debugging) - This is where VS Code really shines
[Link] (/docs/nodejs/nodejs-tutorial) - End to end [Link] scenario with a sample app

Common questions

How can I find out what command is bound to a specific key?


In the Keyboard Shortcut editor, you can filter on specific keystrokes to see which commands are bound to which keys. Below you can see that Ctrl+Shift+P is bound
to Show All Commands to bring up the Command Palette.

How to add a key binding to an action, for example, add Ctrl+D to Delete Lines
Find a rule that triggers the action in the Default Keyboard Shortcuts and write a modified version of it in your [Link] file:

// Original, in Default Keyboard Shortcuts


{ "key": "ctrl+shift+k", "command": "[Link]",
"when": "editorTextFocus" },
// Modified, in User/[Link], Ctrl+D now will also trigger this action
{ "key": "ctrl+d", "command": "[Link]",
"when": "editorTextFocus" },

How can I add a key binding for only certain file types?
Use the editorLangId context key in your when clause:

{ "key": "shift+alt+a", "command": "[Link]",


"when": "editorTextFocus && editorLangId == csharp" },

I have modified my key bindings in [Link]; why don't they work?


The most common problem is a syntax error in the file. Otherwise, try removing the when clause or picking a different key . Unfortunately, at this point, it is a trial and
error process.

[Link] 14/15
22/5/23, 8:01 Visual Studio Code Key Bindings

Was this documentation helpful?

Yes No

5/3/2023

IN THIS ARTICLE

Keyboard Shortcuts editor

Keymap extensions

Keyboard Shortcuts Reference

Detecting keybinding conflicts

Troubleshooting keybindings

Viewing modified keybindings

Advanced customization

Keyboard rules

Accepted keys

Command arguments

Running multiple commands

Removing a specific key binding rule

Keyboard layouts

Keyboard layout-independent bindings

when clause contexts

Custom keybindings for refactorings


{ Default Keyboard Shortcuts

Next steps

Common questions

Tweet
([Link]
this
original_referer=[Link]
link
Subscribe(/[Link])
Ask questions([Link]
Follow @code([Link]
Request features([Link]
Report issues([Link]
Watch videos([Link]

Hello from Seattle. Follow @code ([Link] Star 146,388

Support ([Link] Privacy ([Link]


Terms of Use ([Link] License (/License)

([Link]
© 2023 Microsoft

[Link] 15/15

You might also like