3605
3597

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

VS Code の便利なショートカットキー

Last updated at Posted at 2017-08-12

Visual Studio Codeを自分が使用する際に便利なショートカットキーを、忘れないようにまとめておく。Windows版。mac版はカッコ書きで随時追記中。Windowsはv1.57で再確認済み。macはv1.96で確認中。
なお、Windows版からmac版への読み替えは基本的にはCtrl→Cmd、Alt→Optで成り立つ場合がほとんどだが一部例外がある。

編集系

  1. Ctrl(Cmd) + Enter カーソル行の下に空行を挿入
  2. Ctrl(Cmd) + Shift + Enter カーソル行の上(というかカーソル行?)に空行を挿入
  3. Alt(Opt) + / カーソル行/選択行をまるっと移動(複数行対応)
  4. Alt(Opt) + Shift + / カーソル行/選択行をまるっとコピー(複数行対応)
  5. Ctrl(Cmd) + C 選択範囲をコピー。非選択状態で使用すると行コピーになる
  6. Ctrl(Cmd) + X 選択範囲を切り取り。非選択状態で使用すると行切り取りになる
  7. Ctrl(Opt) + BS 単語の部分削除(カーソル位置より左側)
  8. Ctrl(Opt) + Del 単語の部分削除(カーソル位置より右側)
  9. (Cmd) + BS カーソル位置より左側をすべて削除
  10. (Cmd) + Del または (Ctrl) + K カーソル位置より右側をすべて削除

1.は次の行を入力したい時、今まではカーソルを一旦行末に持っていってからEnterとかやっていたが、カーソルが行の途中にあってもパッと次の行が入力できるので便利。
3.は移動距離が近ければいちいちコピペしなくてよいので便利。
7.8.に関連して単語の削除(Delete Word)というコマンドがv1.52から追加されたがショートカットキーは定義されていない。
9.10.はmacのみショートカットキーが登録されていてWinでは未登録。ただしコマンド自体は存在するので自分で登録するかF1でコマンド(Delete All Left/Right)を入力して呼び出すかすれば使用できる。

移動/スクロール/分割系

  • Ctrl + Home/End (Cmd + /) エディタの先頭/末尾に移動
  • Home(Cmd+) 行頭に移動。
    • インデントされている行の場合は文字の先頭に移動する。もう一度押すと行頭に移動する。さらに押すとまた文字の先頭に移動する。
    • さらに、折り返し表示の行の場合は、物理行の文字の先頭→論理行の文字の先頭→行頭と移動する。
  • End(Cmd+) 行末に移動。
    • 折り返し表示の行の場合は、物理行の行末→論理行の行末と移動する。
  • Alt(Opt) + Z 折り返しする/しないの切り替え
  • Ctrl(Opt) + / 単語の先頭にジャンプ
  • Ctrl + / カーソル位置はそのままで上下にスクロール(macの場合もキーは同じだがただしmacの場合はMissionControlのショートカット操作が優先されてしまう)
  • Alt + PgUp/PgDn (Cmd+fn+/) カーソル位置はそのままでPageUp/PageDown
  • Ctrl(Cmd) + Shift +  対応する括弧にジャンプ(言語によっては対応していない)
    • はキーボード右上の円記号のキーを使用する。右下にバックスラッシュのキーがあるがこちらは反応しないので注意。
  • Ctrl + G 指定した行(列)にジャンプ(macも同じキー)
    • 行番号を入力するとその行に仮ジャンプする。Enterを押すと行移動が確定し、Escを押すと元の位置に戻る。
    • 行番号にマイナス値を指定すると、最下行からの相対行にジャンプできる(v1.38以降)
    • 行番号の後ろにカンマ区切りで列位置も指定できる。
  • Ctrl(Cmd) + K Ctrl(Cmd) + Q 最後の編集位置に移動(ver1.28以降)
    • 間違えて変な場所にジャンプしてしまった時に便利!
  • Ctrl(Cmd) + U カーソル移動を1つ前に戻す(CursorUndo)。ただしカーソル移動のみのundoなので途中に文字入力などの編集操作があるとそれ以前には戻れない。また、逆の操作のCursorRedoコマンドも存在する(ver1.40以降)がショートカットキーには登録されていないので自分で登録するか毎回コマンドパレット(F1)で呼び出す必要がある。
  • Ctrl(Cmd) + K Ctrl(Cmd) + Shift + 同一エディタ内でエディタを分割/解除(v1.61以降)
    • 分割方向を変更するにはエディタを分割した状態で右上のレイアウトの切り替えボタンを押す

なお、キャメルケースやスネークケースの単位で移動や選択などを行うコマンドも存在するが、デフォルトではキー割り当てはされていないため、使用したい場合は自身でキー定義を行う必要がある。

  • 左へ移動(cursorWordPartLeft)
  • 右へ移動(cursorWordPartRight)
  • 左へ選択(cursorWordPartLeftSelect)
  • 右へ選択(cursorWordPartRightSelect)
  • 左へ削除(deleteWordPartLeft)
  • 右へ削除(deleteWordPartRight)

ちなみに、これらのコマンドが追加された当初は、左への移動や選択のコマンド名は~Left/~LeftSelectではなく、~StartLeft/~StartLeftSelectだったが、分かりづらいためStart無しに変更された。ただし互換性を考慮して以前のコマンド名もエイリアスとして残されているため、ショートカットの設定画面ではこれらの旧コマンド名も表示される。
image.png

選択系

  • Shift + / カーソル移動しつつ文字選択
  • Ctrl + Shift + / 単語単位でカーソル移動しつつ選択
    • 上記2つのコマンドは非選択状態で使用すると現在のカーソル位置を起点に選択が始まる。選択状態で使用するとその選択をキープしたままの追加選択となる。さらに/の代わりに/キーを押すとカーソルを行移動しつつの選択となる。
  • Ctrl + D 単語選択。本来は複数選択のためのキーだが1回だけ使用する場合は実質的な単語選択として使える(ことが多い)。
  • Ctrl + L 行選択してカーソルを下の行に移動。つまり連続して押していくと1行ずつ行選択が増えていく。
    • ver1.31以前はCtrl + Iだった

アンカーを使用した範囲選択(v1.46~)

  • Ctrl + K Ctrl + B カーソル位置にアンカー(目印)をセットする
  • Ctrl + K Ctrl + K アンカーからカーソル位置までの間を選択する
  • Esc アンカーの解除

なお、関連するコマンドとして**選択アンカーへ移動(Go to Selection Anchor)**というのが存在するがデフォルトではキー定義されていない。

スマート選択

  • Shift + Alt + / スマート選択の範囲の拡大/縮小

どのような単位で選択されるかは言語モードによって異なる。
IntelliJ IDEAでいうところのCtrl + Wに相当。
Javaのスマート選択については今まではなんとなくな感じの対応だったが最近正式に対応になった。

スマート選択の例(Javaコードの場合)
リテラル値にカーソルがある状態で選択範囲を広げると、まずリテラル値全体が選択され、次に引用符までが選択され、次にステートメント全体まで、...と拡がっていく。
java_smart.gif

マルチカーソル/複数選択/矩形選択系

マルチカーソル

  • Alt + Ctrl + / マルチカーソルを上/下に広げる。
    • マウス操作の場合はAlt+クリックでカーソル追加。コマンドマルチカーソル修飾子の切り替え(Toggle Multi-Cursor Modifier、メニューバーの場合は選択-マルチカーソルをCtrl+Clickに切り替える)を実行するとCtrl+クリックに切り替わる。

複数選択

  • Ctrl + D 選択されている文字列(あるいはカーソル周辺の単語)を選択に追加。複数回追加するとマルチカーソル状態になる。Ctrl+Shift+Lの個別版。選択状態を1つ前に戻したい時はカーソルUNDO(Ctrl+U)を使用する。
  • Ctrl + Shift + L 選択されている文字列(あるいはカーソル周辺の単語)と一致する文字列をすべて選択する。複数個選択した場合はマルチカーソル状態になる。Ctrl+Dの一括版。

矩形選択

  • Ctrl + Shift + Alt + /// 現在のカーソル位置を起点に矩形選択。選択が複数行の場合はマルチカーソル状態になる。
    • マウス操作の場合はAlt+Shift+ドラッグ。
  • 矩形選択された状態で Ctrl + Shift + Alt + PgUp/PgDn を押すと、上/下方向にページ単位で選択を拡張する。

いずれもESCを押すかあるいはマウスクリックで解除される。
マルチカーソル機能はすべてのカーソル位置に対して同じキー操作が行われるので、コードの中の複数箇所を同じように修正したい場合などに結構便利。

検索系

エディタ内検索

  • Ctrl + F エディタ内の検索
    • 文字を選択している(またはハイライトされている)状態の時は、その文字列が自動的に入力フィールドにセットされる。
  • Ctrl + H エディタ内の置換
    • 置換ダイアログが開いている状態でCtrl + Hを押すと、押す度に2つの入力フィールド間でフォーカスが移動する。

検索中の操作

  • F3 / Shift + F3 次の/前の検索結果にジャンプ
    • 検索の入力フィールドにフォーカスがある時はEnter / Shift+Enterでも可。
  • エディタにフォーカスがある時に検索の入力フィールドにフォーカスを移動させるにはCtrl+Fを押す。
  • Alt + C 大文字小文字の区別をする/しないの切り替え
  • Alt + W 単語単位で検索する/しないの切り替え
  • Alt + R 正規表現で検索する/しないの切り替え
  • Alt + L 選択範囲内で検索する/しないの切り替え

フォルダ/ワークスペース全体

  • Ctrl + Shift + F フォルダ/ワークスペース全体を検索
    • 特定のフォルダ配下を検索したい場合はファイルエクスプローラでフォルダを右クリックして「フォルダー内を検索」
  • Ctrl + Shift + H フォルダ/ワークスペース全体を置換
  • F4 / Shift + F4 次の/前の検索結果にジャンプ

共通

  • (入力フィールド内で)(Alt +) / 検索(置換)履歴の表示

開く系

  • Ctrl + N 新規にエディタを開く(閉じるのはCtrl + W
  • Ctrl + Shift + N 新規にウィンドウを開く(閉じるのはCtrl + Shift + W
  • Ctrl + P フォルダ/ワークスペース内のファイルを開く
    • キーワードを入力するとファイルが絞り込まれる。スペースで区切ってさらにフォルダ名で絞り込むことも可能。さらに@で区切ってファイル内のシンボルを選択することも可能。
    • /でファイル/シンボルを選択し、Enterでファイルを開く。Ctrl+Enterで現在開いているファイルの横に開く。
  • Ctrl + , 設定画面を開く
  • Ctrl + K Ctrl + S ショートカットキーの設定を開く(Keyborad Shortcutと覚える!)
  • Ctrl + Q Quick Open ビュー。Ctrlを押しながらQを打つとメニューが表示されるので、そのままCtrlは離さずにQをポンポン打っていくとメニューフォーカスが移動する。開きたい項目までフォーカスが移動した状態でCtrlを離すとビューが開く。
    • フォーカスの移動は/Shift+Qでも可(いずれもCtrlは押しっぱなし)
    • この操作で開けるビューは、サイドバー、パネルはもちろん、エクスプローラやデバッグの中のカスタムビューや、ターミナルや出力パネルの出力内容も直接選択して開くことができるので結構便利。
  • サイドバー系
    • Ctrl + B サイドバーを開く/閉じる
    • Ctrl + Shift + E エクスプローラーを開く
    • Ctrl + Shift + F 検索を開く
    • Ctrl + Shift + G ソース管理を開く
    • Ctrl + Shift + D デバッグを開く
    • Ctrl + Shift + X 拡張機能を開く
      • 検索を開く以外は、もう一度キーを押すとサイドバーを開いたまま、エディタにフォーカスが戻る
  • パネル系
    • Ctrl + J パネルを開く/閉じる
    • Ctrl + Shift + U 出力を開く/閉じる
    • Ctrl + Shift + M 問題を開く/閉じる
    • Ctrl + Shift + Y デバッグコンソールを開く/閉じる
    • Ctrl + @ 統合ターミナルを開く/閉じる
      • 閉じるのは表示を閉じるだけでターミナル自体は終了しない
      • Ctrl+J以外の個別パネル操作については、v1.28から挙動が変わり、パネルが表示されていてフォーカスがパネル以外の場所にある時にキーを押すとそのパネルにフォーカスが移動するようになった

閉じる系

  • Ctrl + F4 アクティブエディタを閉じる。
  • Ctrl + W アクティブエディタを閉じる。開いているエディタが無い場合、VS Code自体を閉じる。(v1.57で廃止)
  • Ctrl + K W エディタグループ内をすべて閉じる
  • Ctrl + K Ctrl + W エディタをすべて閉じる
  • Ctrl + Shift + W または Alt + F4 ウィンドウを閉じる

ファイル保存系

  • Ctrl + S 上書き保存
  • Ctrl + Shift + S 名前を付けて保存
  • Ctrl + K S すべてのファイルを保存
  • Ctrl + K Ctrl + Shift + S 自動フォーマットをせずに保存(v1.28以降)
    • 通常の保存では言語モードごとのフォーマットが自動的に行われるが、それせずにそのまま保存したい時に使う
  • Ctrl + K D 差分ビューが開き、未保存の変更箇所を確認できる
    • Alt + F5で次の変更箇所にジャンプできる
    • また、差分ビューのまま編集をすることも可能
    • 確認が終わったらCtrl+Wなどで閉じる
    • 「あれ?このファイルいつの間にか未保存状態になってるけどどこ直したっけ?」みたいな時に便利

フォーカス移動系

  • Ctrl + 0 サイドバーにフォーカスを移動
  • Ctrl + 1 1つ目のエディタグループにフォーカスを移動
    • エディタグループを1つしか使用していない場合は上記2つのショートカットキーでサイドバーとエディタを行き来できる。
    • +2,+3...,+8まで可能
  • Ctrl + M タブキーによるフォーカス移動モードになる。
    • 解除も同じキー操作だがフォーカスの位置によっては効かない場合もある。

言語モード系

  • Ctrl + K M 言語モード(JavaとかHTMLとか)を変更する
    • で選択、Enterで決定、Escでキャンセル
    • キーワードを入力すると選択肢の絞り込みができる

なお、WindowsでIMEがオンになっている場合、Mの入力がIMEに横取りされてしまい、正しくコマンドを実行することができないので、この機能をショートカットキーで多用する場合はキーバインドを変更したほうが便利。
例えばCtrl+K Ctrl+Mなど。ただしこのキーバインドはすでに定義されているが使用頻度が低い機能(各種キーマップ定義の拡張機能のおすすめを表示)なのでそちらのキーバインドは削除するか、またはエディタにフォーカスがある場合だけ言語モード切り替えが作動するように起動条件にeditorTextFocusを設定する。
change_langmode.jpg

エディタレイアウト系

エディタグループについて

  • 1つのエディタが表示されている領域のことをVS Codeではエディタグループと呼ぶ。
  • 1つのエディタグループ内には複数のエディタを含めることができ、タブ切り替えによってアクティブなエディタを切り替える。

image.png

  • エディタを並べて表示したい場合はエディタグループを分ける。

image.png

  • v1.24まではエディタグループは最大3つまでしか配置できず、また可能な配置も単方向のみだったが、v1.25でグリッドエディタレイアウトが採用されそれらの制限が無くなった。詳しくはこちらの記事を参照。

エクスプローラからの操作

  • ファイルを選択してCtrl + Enter 新規のエディタグループでファイルを開く(開いたファイルがアクティブになる)
    • またはファイル右クリックで横に並べて開く
  • または Ctrl + ファイルクリック(アクティブエディタは変わらず) この機能はv1.20から複数選択の操作に変更になった

エディタ/エディタグループの操作

分割/閉じる系

  • Ctrl +  エディタの分割(設定されている方向)
  • Ctrl + K Ctrl +  エディタの分割(設定とは逆方向)
    • デフォルトの分割方向は設定workbench.editor.openSideBySideDirectionにて指定(右方向or下方向)する。
  • Ctrl + 18 新たにエディタグループを作成する。あるいはすでに表示されているエディタグループにフォーカスを切り替える。
    • 新規の場合は空のエディタグループが作成される。
    • 新規の場合は1つ前のエディタグループが存在する時のみ作成される。
  • Ctrl + W / Ctrl + F4 アクティブなエディタを閉じる
  • Ctrl + K W アクティブなエディタグループ内のエディタをすべて閉じる
  • Ctrl + K Ctrl + Shift + W すべてのエディタグループを閉じる

エディタ移動系(別エディタグループへ)

  • Ctrl + Alt + / アクティブなエディタを隣のエディタグループに移動する。隣にエディタグループが存在しない場合は新たに作成される。
  • Shift + Alt + 1/9 アクティブなエディタを先頭/最後のエディタグループに移動する。新たにエディタグループは作成されない。

フォーカス移動系

  • Ctrl + PgUp/PgDn エディタグループを横断してのアクティブエディタの切り替え
  • Ctrl + Tab エディタグループ内でのアクティブエディタの切り替え
    • 正確には、Ctrlキーを押しっぱなしの状態でTabキーをポンポン押していくと切り替え先のエディタを選択でき、Ctrlキーを離すとエディタが切り替わる。
    • また、Ctrlキーを押しっぱなしの状態でTabキーを押して一旦離し、/キーで切り替えるエディタを選択し、Ctrlキーを離すとエディタが切り替わる。
  • Ctrl + K Ctrl + /// アクティブなエディタグループを切り替える

エディタグループ移動系

  • Ctrl + K /// アクティブなエディタグループをグループごと移動

レイアウト系

  • Alt + Shift + 0 エディタグループの横方向/縦方向の切り替え

なお、エクスプローラからのファイル配置や、エディタグループ間のエディタ移動、レイアウト変更などはドラッグ&ドロップでも行える。エディタの移動はタブをドラッグする。ドロップ先のエディタの選択状態が全面の時にドロップするとそのエディタグループへの移動となり、エディタの選択状態が半分の状態でドロップするとその方向に新たにエディタグループが作られる。

折りたたみ系

インデントの折りたたみ

  • Ctrl + K Ctrl + 0 すべてのインデントを折りたたむ
  • Ctrl + K Ctrl + 1 1段目のインデントをすべて折りたたむ(同様に9段目まで指定可 現在は7段目まで)
  • Ctrl + K Ctrl + J すべてのインデントを展開する
  • Ctrl + Shift + [ カーソルのあるインデントを折りたたむ
  • Ctrl + Shift + ] カーソルのあるインデントを展開する
  • Ctrl + K Ctrl + [ カーソルのあるインデントを子インデント含め折りたたむ
  • Ctrl + K Ctrl + ] カーソルのあるインデントを子インデント含め展開する
  • Ctrl + K Ctrl + L カーソルのあるインデントを折りたたむ/展開する(トグル操作。Ver1.39から)
  • Ctrl + K Ctrl + / すべてのブロックコメントを折りたたむ

言語モードによっては対応されていないコマンドもある。
また、インデントの対応が正しくなっていないとうまく動作しない場合がある。

任意の範囲の折りたたみ設定(v1.70~)

  • Ctrl+K Ctrl+, 選択された範囲の折りたたみ設定を有効にする
  • Ctrl+K Ctrl+. カーソル行の任意折りたたみ設定を解除する

任意範囲の折りたたみ設定はファイルを開き直しても維持される。

ワークベンチ内のフォーカス移動(v1.45~)

  • F6 ワークベンチ内のフォーカス移動
  • Shift + F6 ワークベンチ内のフォーカス移動(逆方向)

F6を押す度にフォーカスが エディタ->パネル->ステータスバー->アクティビティバー->サイドバー と切り替わる。Shiftを押しながらだと逆方向。
ただしサイドバーやパネルを閉じている時はそれらへのフォーカス移動はスキップされる。
同様に、設定でステータスバーやアクティビティバーを非表示にしている時もそれらへのフォーカス移動はスキップされる。
各エリア内のフォーカス移動は矢印キーで行う。

設定系

設定画面(Ctrl+,

  • 設定の検索入力フィールドにキーワードを入力して絞り込み
  • Esc 入力フィールドをクリア
  •  設定項目にフォーカス移動

配色テーマの変更(Ctrl+K Ctrl+T

(ショートカットはKolor Themeと無理やり覚えれば覚えやすい?)

  • / 配色テーマのプレビュー
  • Enter 配色テーマの決定
  • Esc キャンセル

フォントサイズ系

画面全体のサイズ変更

  • Ctrl + テンキーの+ フォントサイズ等を大きくする。
    • Ctrl + Shift + ;でも可(つまりCtrl++)
    • Ctrl + ;でも可
  • Ctrl + テンキーの- フォントサイズ等を小さくする。
    • Ctrl + Shift + -でも可
    • Ctrl + -でも可
  • Ctrl + テンキーの0 フォントサイズ等をリセットする。
  • フォントだけでなく、左端や下部のバーのサイズも変わるので、全体的にサイズを変更できる。

エディタフォントのみのサイズ変更(v1.24~)

v1.24からエディタフォントのみのサイズ変更が行えるようになったが、デフォルトではキー設定されていないので自分でショートカットキーの設定を行う必要がある。
ショートカットキーの設定画面にて以下のコマンドにキーを割り当てると使用できるようになる。

  • editor.action.fontZoomIn
  • editor.action.fontZoomOut
  • editor.action.fontZoomReset

設定例(画面全体のサイズ変更のキーにAltを加えた)
change_fontsize.jpg

3605
3597
10

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3605
3597

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?