Visual Studio Codeでパス補完機能を細かく設定して自分好みにできる拡張機能「Path Autocomplete」

Visual Studio Codeではデフォルトの状態でも、ある程度パスの入力補助がついていますが、拡張機能を使うことでさらに細かい設定ができて便利になります。
今回はパス入力を効率化する「Path Autocomplete」についてまとめておきます。
Path Autocomplete

Path Autocompleteはsrcやhref属性のパス候補を表示してくれる拡張機能です。
他に似た有名な拡張機能に「Path Intellisense」がありますが、Path Autocompleteは候補に表示したくないファイルを、いま開いているファイルの拡張子に合わせて条件を細かく設定できます。
Path Intellisenseも候補に表示するファイルの設定はできますが、全ファイル共通の設定になってしまいます。
たとえば、.scssファイルを開いているときは.scssファイルもインポートするために使いますが、.htmlを開いているときは.scssファイルは候補に出したくないなどの細かい設定ができます。
フォルダ分けしておけばあまり困ることはありませんが、条件設定の細かさからPath Autocompleteを使っています。
ただし、Path Intellisenseの方がインストール数は断然多いので、とりあえずメジャーな方を使っておくという意味ではPath Intellisenseの方が良いかもしれません。
基本的な使い方
拡張機能を有効化後は、デフォルトの自動補完機能を無効化するために、下記設定を追加します。
{
"javascript.suggest.paths": false,
"typescript.suggest.paths": false,
}あとはパスを入力しようとすると自動で候補が表示されます。
| 入力 | 表示される候補 |
|---|---|
| ./ | 現在のディレクトリからのファイル候補 |
| / | ルートディレクトリからのファイル候補 |
| ~/ | ユーザーのディレクトリからのファイル候補 |
Visual Studio Codeデフォルトの補完機能には「~/」でのユーザーディレクトリからの候補選択ができないので、これを入力することで拡張機能がインストールされているかどうか判断できます。
もしくは、「Path Autocomplete」で補完されるサジェストの項目がアクティブになったときに、フォルダ・ファイル名の右隣にパスが表示されます。

設定の変更
候補に表示しないファイルを指定する
デフォルトの状態だと、すべてのファイルが候補として表示されてしまうため、表示したくないファイルは「”path-autocomplete.excludedItems”」に設定しておくことで非表示にできます。
*(アスタリスク)を使いながら、どの拡張子やフォルダを候補に表示しないか入力します。
そして、{ "when": "" }の中に条件を適用するファイルを指定します。
**を指定すると全ファイルになりますし、**/*.htmlとすると.htmlファイルのみで条件が適用されます。
{
"path-autocomplete.excludedItems": {
"**/.*un~": { "when": "**" },
"**/*.js": { "when": "**/*.ts" },
"**/*.map": { "when": "**" },
"**/{.git,node_modules}": { "when": "**" }
}
}フォルダ補完後の自動スラッシュ入力
デフォルトだとフォルダ補完後に自動でスラッシュは入力されないので、自分で入力する必要がありますが「”path-autocomplete.enableFolderTrailingSlashboolean”」を「true」にするとスラッシュが自動で入力されるようになります。
{
"path-autocomplete.enableFolderTrailingSlashboolean": true,
}Markdownやプレーンテキストでも補完できるようにする
Markdownやプレーンテキスト以外でも補完機能を使えるようにするためには「”path-autocomplete.triggerOutsideStrings”」を「true」にすると補完できるようになります。
{
"path-autocomplete.triggerOutsideStrings": true
}引用符の外側でも補完できるようにする
デフォルトだと””の中でのみ発火しますが、「”path-autocomplete.triggerOutsideStrings”」を「true」にするとどこでも補完できるようになります。
{
"path-autocomplete.triggerOutsideStrings": true
}どこでも発火されてしまうと逆に邪魔になることの方が多いですし、引用符外で使うこともないので基本的にはデフォルトのままで良さそうです。
絶対パスの設定
デフォルトだと絶対パスはワークスペースのルートパス内にされます。
基本的にはこの設定の方が便利だと思いますが、ディスクルートパスへの絶対パスに変更するためには、「”path-intellisense.absolutePathToWorkspace”」を「false」に設定します。
{
"path-intellisense.absolutePathToWorkspace": false,
}マッピング設定
特定フォルダを絶対パスのルートに設定したい場合や、Webpackでパスを使用したい場合は「”path-intellisense.mappings”」でマッピング設定ができます。
"path-autocomplete.pathMappings": {
"/": "${folder}/src",
"/test": "${folder}/src/Actions/test",
"$root": ${folder}/src
}「${folder}」を使うと、ワークスペースのトップのパスが指定されます。
Visual Studio Codeのデフォルト機能だとこの辺りの設定ができないので、この辺の設定ができるのが補完機能の拡張機能を使うメリットです。


WordPress5.5のサイトマップ機能を無効にする
Visual Studio Codeの「Debugger for Chrome」でJavaScriptのデバッグを行う
SourceTreeのカスタムアクションを使って差分ファイルだけをまとめる方法
gulp-sass 5の「does not have a default Sass compiler」エラーを解消する
Visual Studio Codeで正規表現にマッチするか確認できる拡張機能「Regex Previewer」
Local by FlywheelでWordPressのローカル開発環境構築のハードルが一気に下がる
Vue CLIのtitleタグやmetaタグの設定方法
Webサイト制作の基礎の基礎、HTMLって何?
CSSのカスタムプロパティ(変数機能)の使い方
JavaScriptで日付をコピーして計算すると、コピー元の日付も変わってしまう場合の対処法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
Figma × Keyboard Maestroでどこまで効率化できる?
マウス操作の完成度が高いウインドウリサイズアプリ「Magnet」
Macで複数ディスプレイを使っている場合に便利な設定集
AppCleanerでMacアプリを関連ファイルごと完全に削除する
操作に没頭できる!Firefox版 Arcのようなブラウザ「Zen Browser」
chezmoi(シェモア)で始めるdotfiles管理
GitHubの通知を見逃さない!通知に特化したアプリ「Gitify」
Keyboard Maestroの変数基礎
Neovimを使い始める最初の一歩として便利な「LazyVim」
ウェブサイトをmacOSアプリとしてラッピングする「Unite Pro」