203

I'm trying to get a shortcut to add a new file under my current working folder. So I navigate to the explorer using Cmd+Shift+e and when I get to the folder I want to create a new class I do Cmd+n which creates me a new file but is not saved anywhere (I'm trying to get a similar behaviour to what ReSharper does for instance).

Is there any other shortcut to get the file created under the folder you have the focus in the explorer? Essentially I could like to get the text box to fill in the name then the file gets automatically saved so that I don't get the prompt later on.

I'm using for reference the following page: https://code.visualstudio.com/docs/customization/keybindings

1
  • This isn't exactly what you want, but I swear by this extension that lets you create files anywhere in your project: marketplace.visualstudio.com/… Commented Oct 17, 2024 at 5:20

9 Answers 9

463

The cmd+n command is by default bound to workbench.action.files.newUntitledFile but what you want is the command explorer.newFile which by default is not bound to a shortcut.

Edit shortcuts file

Hit Cmd+Shift+p type key and hit enter on Preferences: Open Keyboard Shortcuts (JSON)

This will open keybindings.json file which stores custom keybindings specified by the current VS Code user.

Enter the following in the custom bindings file (presumably you need to enter cmd+n instead of ctrl+n but I'm on windows so can't test

[ { "key": "ctrl+n", "command": "explorer.newFile" } ] 

If you want to only have this apply when the explorer is focused you can add a when condition:

{ "key": "ctrl+n", "command": "explorer.newFile", "when": "explorerViewletFocus" } 

This way when any other component is focused pressing Ctrl+n will execute the default new file command

Edit using shortcuts UI

Hit Cmd+Shift+p type key and hit enter on Preferences: Open Keyboard Shortcuts

This will open up the keyboard shortcut preferences UI.

Type explorer.newFile in the search to find the new file command, double click it to bring up the shortcut capture modal and press the key combination you want to associate with this command.

Sign up to request clarification or add additional context in comments.

7 Comments

This will create the new file in the currently focussed folder. Is it possible to create the new file from the project root?
Is there any reason why "key": "a" wouldn't work? It works only if I do cmd+n
@OliverJosephAsh This extension will do that for you: marketplace.visualstudio.com/…. It lets you type the exact path relative to the project root that you wish to create a file (or multiple files at once).
Also wanted to add for others: This answer depends only on the folder focussed in the workspace menu, not the explorer as a whole. Was trying to figure out why clicking a file in "Open Editors" then triggering this shortcut was creating the file in a different directory. You have to click a file in the directory you want in the workspace menu first. The open editors menu has no effect.
Third point: that extension also adds "Create File" and "Create Folder" options to the context menu in the workspace menu.
|
60

To add files or folders add the following lines to keybindings.json:

Updated answer on 2020/02/10 (Thanks to @AbrahamHernandez, who provided the comment).

[ { "key": "ctrl+n", "command": "explorer.newFile", "when": "!editorFocus" }, { "key": "ctrl+shift+n", "command": "explorer.newFolder", "when": "!editorFocus" } ] 

These bindings are active if the editor is not focused.

They are also triggered if the debug window is active. That's not perfect but the context explorerFocus is going to be added in the near future: see GitHub

3 Comments

This didn't work for me: It gives me workbench.action not found
@AbrahamHernandez try changing the commands to explorer.newFile and explorer.newFolder
@gregor-woiwode Good news! As you mentioned, the explorerViewletFocus trigger was added to Visual Studio Code in early 2017, and it is now fully functional. It may be best to update the answer to reflect that, so that even more people can enjoy your solution. I myself found it tremendously helpful. Thank you for the great insight!
27

You can use this method if you don't want to create a shortcut.

  1. Navigate to the explorer via cmd+shift+e
  2. Get to the folder you want to create a new file/folder in.
  3. Open the file picker via cmd+shift+p
  4. Then type New File or New Folder and enter.

That is how you create a new file/folder without touching the mouse. :)

6 Comments

I went to keyboard shortcuts (open with ctrl+K ctrl+S) and added one for explorer.newFile to skip steps 3 and 4.
I think step 3 should be cmd+shift+p?
@Rafi you are right. I added to the message. Thanks.
Than-ks. It's worth knowing the shortcuts to navigate through VS
For step 4, VS code prompt me both Create: New File and File: New File. The latter is the right one
|
5
 { "key": "ctrl+n", "command": "explorer.newFile", "when": "explorerViewletFocus" } 

Paste it in the Keybindings.json by pressing F1 key and search for Preference: Keyboard(JSON).

1 Comment

Your answer could be improved with additional supporting information. Please edit to add further details, such as citations or documentation, so that others can confirm that your answer is correct. You can find more information on how to write good answers in the help center.
1

You can try this extension, it allows you to create files and folders even if the source being clicked is a file.

Demo:

Demo

Comments

1

Use ctrl+shift+p and search for "Preferences: Open Keyboard Shortcuts"

Then, inside the keybindings menu, search for "explorer.newFile"

you can bind it to ctrl+n, and set the "When" property to "explorerViewletFocus", so this command will only happen when the focus is in the explorer

Similarly, you can change "explorer.newFolder" to ctrl+shift+n and the "When" condition to "explorerViewletFocus", like before.

Now you can open files and folders via keyboard inside the selected folder

I preferred this solution to the other ones since I did not have to open that huge json file with the keybindings

Comments

0

You can do it in two steps:

  1. Cmd + Shift + E: Open the explorer with
  2. Ctrl + N: Create a new file under the current folder and name it.

I actually like this approach than the magical-one-click because each step is clearer and you don't have to configure anything.

Comments

0

As for 2021 VSCode on mac the CMD + SHIFT + N opens a new VSCode window. If you want to change the behaviour and create new folders using only keyboard do the above to change keybinding:

  1. Press CMD + SHIFT + P and search for new folder then click on setting icon on the right side of search result.

  2. This brings up Keyboard Shortcut tab here you can change keybinding for new folder, click on pen icon and enter your desired keybinding and press ENTER

Comments

0

Try CTRL WIN ALT N While highlighting a file. Enter file name, double enter. Enjoy!

1 Comment

I'm on a Mac and have the Emacs binding extensions which use Ctrl-N. Your comment let me find that on Mac, this works nicely: Ctrl-Opt-Cmd-n

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.