Published: 06 August 2017
Lately I have been using my Mac as my main daily driver. I still spin up Parallels from time to time when I need to do something inside Visual Studio, but for most of my C# work I use VS Code (and .NET Core). This blog post contain some notes about using VS Code for your C# and .NET Core development which may make your life easier.
As a side note, I have also actually started looking seriously into JetBrains Rider as I miss the powerful refactoring capabilities from Resharper.
Installation of VS Code and the .NET Core command line tools are pretty straight forward and many resources are available. For installing VS Code you can refer to the Setup section of the official documentation. It provides step-by-step instructions for Windows, Linux and Mac.
For dowbloading the .NET Core SDK you can refer to the Download section of the .NET website. You can also refer to the Get Started with .NET Core document which contains more detailed steps. It also contains a nice video walkthrough of installing both VS Code and .NET Core.
The Visual Studio website contains pretty amazing documentation which will help you get started with the basics of using the editor. Also refer to Working with C# to get a better understanding of the C# support inside VS Code.
Out of the box, VS Code has very limited support for C#. It does however allow you to enrich the standard functionality by installing extensions. You can discover extensions either from inside VS Code, or from the Visual Studio Code Marketplace.
The VS Code Extension Marketplace document contains more information about how to install extensions. Also refer to Using Extensions in VS Code which contains a video walktrough of installing extensions.
Below are some extensions I recommend you install to get the most from VS Code for C# (and ASP.NET Core) development.
C#. This extension adds Syntax Highlighting, Intellisense, Go To Definition, Find All References, etc. It also add debugging support for C# applications.
For Debugging I also suggest you refer to Instructions for setting up the .NET Core debugger
C# Extensions. This adds functionality to easily add a new C# class or Interface. This is useful because just creating a new file inside VS Code simply creates an empty file. This extension creates a new file for a
interface for you, and also sets up the correct
namespace for your project, as well as include the basic
C# Snippets. Contains many useful C# code snippets.
C# XML Documentation Comments. Makes adding XML comments to your code a much more pleasant experience.
ASP.NET Core Snippets. Contains snippets for easily constructing ASP.NET Core Controllers and Actions.
WilderMinds’ ASP.NET Core Snippets. An alternative to the ASP.NET Core Snippets extension adding a very similar set of snippets.
ASP.NET Helper. Adds Intellisense inside Razor view pages.
HTML Snippets. Adds support for HTML syntax highlighting, as well as HTML snippets.
BTW, VS Code also includes amazing built-in Emmet support inside VS Code, which makes coding of HTML much faster.
IntelliSense for CSS class names. Provides CSS class name completion for the HTML class attribute based on the CSS class definitions in your project.
Git Extension Pack. If you are using Git, then this is an Extension Pack which installs 5 different extensions which adds a lot of very useful Git capabilities to VS Code (over and above what is already built in).
One major pain point coming from Visual Studio (and Resharper) is the lack of proper code refactoring tools. There is however some hope, as you can - with some manual effort - get some of the Visual Studio Roslyn-based refactoring extensions to work inside VS Code.
For more information on how to do this, please refer to Using Roslyn refactorings with OmniSharp and Visual Studio Code by Filip W. It is not a perfect solution, but it is a good start.
Are you struggling to stay up to date with all that is happening in the ASP.NET world?
I publish a weekly newsletter with all the best ASP.NET related news and blog posts of the previous week
Sign up with your email address below to get it delivered to your Inbox every Friday!