Flutter — Visual Studio Code Shortcuts for Fast and Efficient Development
Visual Studio Code Shortcuts for Fast and Efficient Development
It is a well known fact that keyboard shortcuts can help us a lot while developing, especially when you have a lot of code to go through and you have to find the opening and closing brackets or insert a new widget or remove one. Time is precious and I find these shortcuts help me a lot in coding in flutter. I became a fan of VS Code mainly because it’s so light weight and opens much faster than other IDEs I have worked with and have a ton of features and customizations along with extensions which can do wonders (This is just my personal opinion).
If you use Android Studio and IntelliJ in Windows, I would recommend you to read this great article or if you use mac you can check out this article.
First of all I hope you have Dart and Flutter Extensions enabled, if not you can get them from here : Dart and Flutter.
Now let’s jump into the shortcuts and see what all wonders we can do.
Keyboard Shortcut List
Firstly, I will provide you the shortcut to get all the shortcuts.
I
won’t be able to explain all the default shortcuts in this article
since the list is huge. You can find the list of default keyboard
shortcuts and also search for shortcuts by using CTRL+K+S
as seen below:
data:image/s3,"s3://crabby-images/e6add/e6add88ae94f90144b5952f78301e9949e5f5e6d" alt=""
Or you can also use Ctrl+Shift+P
to Show Command Palette with the recently used commands or also to search commands.
data:image/s3,"s3://crabby-images/55041/55041aec6c82f641b6cda73e63c60822d40e78b3" alt=""
Or you can take a printout of all the default VS Code keyboard shortcuts from here. You can get the official dart custom shortcut list from here and flutter vs code extension documentation.
Code Assist or Code Completion
While
coding, this is one of the important tools especially for beginners or
if you get stuck somewhere and want to check for options, you can use Ctrl+Space
to get a list of curated code completion options.
data:image/s3,"s3://crabby-images/eb4f8/eb4f8f6fae38a2afc5248e586da1aaa7b5d58027" alt=""
Quick Fix or the Magic Wand
For faster development in flutter you can use the quick fix tool with is Ctrl+.
, it helps in fixing the code with some additional requirements without
messing with your code or your widget structure and giving you less
headache of manually correcting everything. Let’s see some of the
examples
Quick Fix Options
As you can see below, when on any widget you can click Ctrl+.
to find the quick fix options.
data:image/s3,"s3://crabby-images/a763a/a763a00b4382107c68baa10209ae86c5b2c09316" alt=""
Let’s explore the menu items one by one :
1. Extract Local variable
You can extract an existing widget and make it a local variable and magically the widget will be replaced by the variable, wherever it is used.
data:image/s3,"s3://crabby-images/5cb22/5cb228e7d3e3668c096577b75c82bc7e97fd3054" alt=""
2. Extract Method
What if you have got a lot of code and you want to split it to different methods. It would even given you a generated name for whatever code you want to split.
data:image/s3,"s3://crabby-images/68892/68892825d27be95a1259ccd6651895e1876e9335" alt=""
But I would advice against splitting widgets to methods, instead you should create a new class as it has a lot of impact on performance, you could refer this article to know in depth why widgets should not be split into methods. You can do this easily using the next menu.
3. Extract Widget
This can come a lot in handy if you want to split your widgets into smaller widgets. Hope by now you know about the importance of splitting widgets to smaller widgets and it’s impact on performance π.
Just click on any widget and then click Ctrl+.
and click Extract Widget
option and give a name for the new widget and click Enter
and that’s it.
data:image/s3,"s3://crabby-images/00463/00463a565e32bd6f24670c2eddf579c2df4435e9" alt=""
4. StatelessWidget to StatefulWidget
Now let’s say, you wanted a StatefulWidget
, but this process only gives you a StatelessWidget
, but there is a cool way to convert the StatelessWidget
to StatefulWidget
, may be by this time you would have guessed it…
Yes, you just have to click the StatelessWidget
and click Ctrl+.
and then “Ta Da” as if it’s magic you will get an option Convert to StatefulWidget
click on that and that’s it π
click on that and that’s it π
data:image/s3,"s3://crabby-images/95a1f/95a1fe4d85075f26d7cc9bd6ea56e33ce4b5f3be" alt=""
5. Add padding
Adding padding to an existing widget is much more easier with the quick assist tool, just select Add padding
and you will get padding around your widget without messing up your widget structure.
data:image/s3,"s3://crabby-images/76240/76240b1d0dfcb5fa2af70898a84b5e9c4f89a8bf" alt=""
6. Center widget
This is used to wrap it with a center
widget, thus centers your widget.
data:image/s3,"s3://crabby-images/aa5ff/aa5ff4781bffa57a5b7c565473008a0387f565d3" alt=""
7. Wrap with Column, Container, Row, StreamBuilder, new Widget
You can use this same technique to wrap your required widget with a Column or Container or Row or StreamBuilder or any other widget or even custom widgets, to make that as your parent widget of the required widget.
data:image/s3,"s3://crabby-images/5ded6/5ded60b8e4b13e16032353236767dda8e182e1dd" alt=""
But, unlike the same tool in android studio, you cannot select multiple widgets to come under a column, as of now that feature is not available.
data:image/s3,"s3://crabby-images/f4053/f40534fda9cfd28c68824eec5e6a1ff08c9978b1" alt=""
You can also wrap with any other widget or a custom widget.
data:image/s3,"s3://crabby-images/e0068/e0068cacb84ba8c049987807ac526969d9194b33" alt=""
data:image/s3,"s3://crabby-images/01d82/01d8209fa19103fefcb410d5703755c3cc26b632" alt=""
data:image/s3,"s3://crabby-images/70b88/70b88cef4e88cbdf6e362e3b277afd0a30008ec9" alt=""
Flutter Specific Shortcuts — Create Stateful or Stateless Widgets
There
are some flutter specific shortcuts as well, which will provide some
boilerplate code to work upon, which you can call by typing prefixes, in
case the menu doesn’t popup you can type Ctrl+space
after typing the prefix.
- Prefix
stless
: Create a new subclass ofStatelessWidget
.
data:image/s3,"s3://crabby-images/dae50/dae50061bab119cf474026d73e8b34d6d1a5e442" alt=""
- Prefix
stful
: Create a new subclass ofStatefulWidget
and it’s associated State subclass.
data:image/s3,"s3://crabby-images/407cd/407cd1455f90ea2e5ff672380a01f2c57d1e1866" alt=""
- Prefix
stanim
: Create a new subclass ofStatefulWidget
, and it’s associated State subclass including a field initialized with anAnimationController
.
data:image/s3,"s3://crabby-images/e2b62/e2b623a80ce1bfff11ebe7f8789080e80316e504" alt=""
Hierarchy
Inorder to see the class hierarchy press F4
on any widget
and in a few seconds you will be able to see the widget hierarchy.
data:image/s3,"s3://crabby-images/d25b5/d25b58fb83dba10789438737efd5e09f2f068554" alt=""
Shortcuts while Coding
Mouse Click Selection
This is very common and is used usually in any editor, you can select any word by double clicking the left mouse button over that word and you can select the whole line by clicking the left mouse button 3 times consecutively.
data:image/s3,"s3://crabby-images/c4e1e/c4e1ec70d6379d3ff5c0a82a28096b23d032b2e1" alt=""
View Source Code
You
can easily see behind the curtains of any widget and know it’s working
or even find out the reason behind your errors or find the required
parameters by going to the widget source code and reading about it,
flutter provides a detailed documentation in the form of comments in the
source code and can help you solve issue faster, in order to do that,
it’s very easy, you just have to press ctrl
and then left mouse click
any widget to go into its source file, or you can use F12
while cursor is on the widget.
data:image/s3,"s3://crabby-images/56523/56523ad1540bf2386a6ae50583f0a1f3d1d52640" alt=""
Cut or Copy and paste a line
You can cut a line by using Ctrl+x
or copy the line using Ctrl+c
when the cursor is at any point on the line and then you can use Ctrl+v
to paste the same.
data:image/s3,"s3://crabby-images/20bb4/20bb40ca69df5bbba433702f508d9e1f4e2d71c3" alt=""
data:image/s3,"s3://crabby-images/c77df/c77df7229dc26b51879cf52dcc95a06636beabe7" alt=""
Go to line Number
You can directly go to any line number by using Ctrl+g
and typing the line number.
data:image/s3,"s3://crabby-images/40f05/40f059fe9409b43d84518ed04029e3364591688e" alt=""
Move a line or a selection up or down
You can move a single line by clicking anywhere on the line and then clicking Alt+
↑ or Alt+
↓ you can move the line one line up or one line down.
you can move the line one line up or one line down.
data:image/s3,"s3://crabby-images/93ba6/93ba6c737e1d5839869328a8967b3b0840f8c962" alt=""
Or you can move a whole selection in same way.
data:image/s3,"s3://crabby-images/8c514/8c5141002095d848cccabe6ccd36a31febf67986" alt=""
Similarly you can use Shift+Alt+
↑ or Shift+Alt+
↓ to copy a line/selection of lines up or down.
Expand/Shrink Selection — Select between Brackets
We
have always come across long code where we have to select between
brackets and this shortcut comes in hand during those times. First click
on either of the start braces or the ending braces and then click Shift+Alt+
→ and magically all the things inside those braces will be selected, you can keep on pressing Shift+Alt+
→ to expand the selection more and you can also shrink the selection by using Shift+Alt+
←
data:image/s3,"s3://crabby-images/0253b/0253b3a183ba842fc5348efc84760da7d755ab70" alt=""
Finding the bracket pair
you can easily find the pair of a bracket using Ctrl+Shift+\
data:image/s3,"s3://crabby-images/7fb41/7fb4113afb7b4a0bcef1f03528f18f1920bf3571" alt=""
Ctrl+Shift+\
Easily trace your steps
Sometimes
while we are coding and traversing through different files or
implementation, we might forget how we reached to this exact code. You
can easily trace your steps by using Alt+
← to see which all code you had come through to get here, you can use Alt+
→ to go forward as well.
data:image/s3,"s3://crabby-images/9d757/9d75728c01b0b7d6ef44d72715100db2afe703b2" alt=""
Switch files/tabs
You can easily switch between open files / tabs using Ctrl+Tab
and then if you hold down Ctrl
and keep pressing Tab
you can choose which tab you want to traverse to.
data:image/s3,"s3://crabby-images/19542/1954277a779ee77470d9376023d4ba8c4f6bfec1" alt=""
Rename/Refactor
You can easily rename any widget by pressing F2
while you are on that widget and then type the new name and then press Enter
data:image/s3,"s3://crabby-images/498aa/498aa9242c14f936e7aec069e09cf93faa4b8ee0" alt=""
Open new workspace
Thanks to Chase Adams
I came to know about this wonderful keyboard shortcut, you have to take
the terminal and go to the location where the workspace is and then
type code -r.
and then that workspace will open in current visual code window. If you want it to open to a new window, use the command code -n.
and it will open the workspace in a new VS code window.
data:image/s3,"s3://crabby-images/49c4d/49c4d89eb2ea28bc1e8c796e1528cf912aaebe9e" alt=""
Code Cleaning Shortcuts
Writing efficient code is difficult and usually it ends up being messy with the usual time constraints and hence before pushing the code to git or any other versioning tool, you would want to clean it up and make it look good with good amount of comments so that it is well maintainable and for that here are some of the keyboard shortcuts which would come in handy.
Format/ Beautify code
While coding, it is a best practice to follow the formatting, but sometimes we just go with the flow and at the worse case we end up with something like this:
data:image/s3,"s3://crabby-images/84586/84586e746a4a91abf4667b3963a1e1f573713e89" alt=""
Now you can easily format this by pressing Alt+Shift+f
to fix your indentation and reformat code.
PS:- Always put trailing commas to get this formatting to work accordingly.
data:image/s3,"s3://crabby-images/fe048/fe048b74f5a644f5bd62124e8d44004aa72a25e8" alt=""
Adding Comments
You can comment any existing line by pressing Ctrl+/
, you can use the same command to un-comment existing comments.
data:image/s3,"s3://crabby-images/9cf14/9cf143653601deb2784f9d5e3b543d726c1cbb66" alt=""
you can select some lines and press Ctrl+/
to comment all lines with prefix //
or Alt+Shift+a
to comment the selected lines by enclosing it inside the symbols/* Your — Code */
, you can use the same command to un-comment the commented lines
data:image/s3,"s3://crabby-images/eb586/eb5862bc2166af0f773b65f31e0de7957657c18a" alt=""
Remove unused imports
Removing
unused imports is a big part of cleaning up code and instead of
removing them one by one, you can directly use a keyboard shortcut to do
it for you. You can easily remove unused imports using Alt+Shift+o.
data:image/s3,"s3://crabby-images/c3adc/c3adc4d04ab7ca0956229f222461c19cd3d564c9" alt=""
Debugging Shortcuts
These are some of the debugging shortcuts which will come in handy, hope you don’t need any examples for the same.
F5
- Start DebuggingCtrl
+F5
- Start Without DebuggingShift
+F5
- Stop DebuggingCtrl
+Shift
+F5
(macOS:Cmd
+Shift
+F5
) - Restart Debugging (Hot Reload when debugging Flutter apps)Ctrl
+F5
- Hot Restart (when debugging Flutter apps and in a debug session)F9
- Toggle BreakpointF10
- Step OverF11
- Step InShift
+F11
- Step Out
I hope I have covered all the shortcuts which I could find and thought are mostly useful, follow me for more tips, tricks and flutter stuff.There are a ton more shortcuts or tips if you are using extensions and I will cover that in a different article so stay tuned π.
If you have any other shortcuts or tips for Visual Studio code, feel free to comment below and let me know.
If you liked this article, please support me by clapping your handsπ as many times as you can.Psst… you can go up to 50 times and I would be more motivated to bring more such articles in the future.
Comments
Post a Comment