data:image/s3,"s3://crabby-images/f9239/f9239057920875a3e01c200fe17ccc83c6c8ab5a" alt="ASP.NET Core MVC 2.0 Cookbook"
How to do it...
- Feature one—VS project templates:
-
- We will find a large number of project templates and samples by going to Menu | File | New Project | Installed.
- Select a project template related to the technology or language you want to develop with.
- We can also download a lot of project templates by going to Menu | File | New Project | Online.
- You can search for a template that matches with a technology.
We want to use all the projects which are not necessarily reliable, so it's up to us to verify that. The New Project dialog box appears:
data:image/s3,"s3://crabby-images/b452b/b452bbda1364cd83056873b07604479aa1bb0506" alt=""
- Visual Studio Gallery to add extensions:
-
- Let's go to Menu | Tools | Extensions and Updates | Visual Studio Gallery.
- We will find some awesome extensions and tools for many languages and technologies. We can go to Visual Studio Gallery (http://visualstudiogallery.com/) to browse all the available extensions:
data:image/s3,"s3://crabby-images/d3026/d3026c8d8fe60883c1efac917ffd149b7153277b" alt=""
-
- An extension can be a VSIX extension, but it can also be an MSI file.
-
- Too many extensions installed make the usage of VS very heavy. You can disable or uninstall any extension you want in the Tools | Extensions and Updates window, shown as follows:
data:image/s3,"s3://crabby-images/4acf6/4acf622f3193aaa0fffa0a1c4ff7529310929696" alt=""
- Searching (classes, methods, interfaces, and many others):
-
- Many options are available for searching. One of the most relevant within VS is searching in the Solution Explorer panel:
data:image/s3,"s3://crabby-images/c8302/c83020ef444b723572c50e875b8ef12058fcc70b" alt=""
-
- If it is not open, we can show it by navigating to View | Solution Explorer:
data:image/s3,"s3://crabby-images/b9311/b93114045c6a9aaaebc67c36e02900b3049c365a" alt=""
-
- We can also search in the Object Browser, the Toolbox, or the Class View panel:
data:image/s3,"s3://crabby-images/a0a9a/a0a9a33de9c6e242834c15d0e360c010b1a97274" alt=""
-
- We can find the Class View panel by navigating to View | Class View.
- We can find the Object Browser panel by navigating to View | Object Browser:
data:image/s3,"s3://crabby-images/48527/48527d82fa7e308bb4761c2be7007a058ea7138d" alt=""
- Code snippets:
-
- Snippets are a way to reuse code and improve productivity, and thus, they help you save time.
- There are many preregistered snippets in VS. For instance, open a C# code file and place the caret within a method definition.
- Type try, then press the Tab key once:
data:image/s3,"s3://crabby-images/3845a/3845a2e85a688ed998101825d4dad1750177fb6e" alt=""
VS generates a try/catch code block, as follows:
data:image/s3,"s3://crabby-images/725b3/725b3fab3bb06a41ce1ed247a91728ec06dd02a5" alt=""
-
- Type if, then press the Tab key once:
data:image/s3,"s3://crabby-images/b5898/b5898f91d1d9eeb3048132c41accbbaa98951a94" alt=""
VS generates an if code block, as follows:
data:image/s3,"s3://crabby-images/25f14/25f14d46ecafdb15a5725deb1d48e689702c9344" alt=""
-
- Type foreach, then press the Tab key once:
data:image/s3,"s3://crabby-images/6d9ea/6d9eaf8513bb463106eda435f28126aae78a1df5" alt=""
VS generates a foreach code block, as follows:
data:image/s3,"s3://crabby-images/bc5ff/bc5ff3505de683601e862ced6ac70aaefdf2ea1b" alt=""
We can replace all the elements of the foreach statement by pressing Tab to navigate between them, then we press Enter to validate.
-
- When selecting code, we can surround it with an existing snippet by typing Ctrl + K and Ctrl + S:
data:image/s3,"s3://crabby-images/94280/94280290832ed4c39ed149f687eff2ab0db9dce6" alt=""
-
- Let's select for, then press the Tab key once:
data:image/s3,"s3://crabby-images/7c16f/7c16fa6c275fcb8a6cd68a7e6aa028ddfe42d224" alt=""
-
- We can use predefined snippets as well as our own snippets. Right-click and click on Insert Snippet... or press the Ctrl + K / Ctrl + X keys:
data:image/s3,"s3://crabby-images/7cf60/7cf60b99723be4c1da3deaa2f6207bc5b7dca426" alt=""
We can consult the default code snippets list on MSDN at https://msdn.microsoft.com/en-us/library/z41h7fat.aspx.
-
- We can see the snippet categories as follows:
data:image/s3,"s3://crabby-images/1d90f/1d90f7ad184a5051fc8eec41af4a40d6a7640eec" alt=""
-
- We can see the snippet list for each category:
data:image/s3,"s3://crabby-images/d14fe/d14fea46a9c85f126ea466a53442f7e62d603293" alt=""
-
- We can explore all the snippets from the menu Tools | Code Snippets Manager.
The Code Snippets Manager dialog box, with all the available snippets, is shown as follows:
data:image/s3,"s3://crabby-images/abf41/abf410c644b5724e8ace63bd8c914fccef4fec31" alt=""
-
- We can also select a list of snippets by language and, afterward, select a category:
data:image/s3,"s3://crabby-images/b982b/b982b0d8e72618c4496827d606fe9593bf8e99e8" alt=""
- Code map:
This feature creates a diagram representing the hierarchy of your method calls, including their classes and DLL containers during debugging. This feature is available only in VS 2017 Enterprise Edition.
-
- We can access it by right-clicking on the code and selecting one of these options on the contextual menu:
data:image/s3,"s3://crabby-images/c6f66/c6f6650ce3ab88d4458a8d5ecd678efa00d3ab76" alt=""
-
- These diagrams can be saved as .dgml extensions, but also as images to be used in a document or to be sent by email.
Code map allows us to do the following things:
-
-
- Navigate and examine code from the map
- Understand relationships between pieces of code
- Find and fix a problem by examining the map
-
data:image/s3,"s3://crabby-images/ebafc/ebafca9a013aa53f0085165f9b215e5f2bb9905d" alt=""
- Analyzers:
There are many analyzers available in NuGet, including Tsql, Azure, and CSharp. Each of them increases the quality of your code, similar to FxCop (a code, analysis tool that gives you advice to correct the code).
Let's explore one of them—code cracker:
-
- Right-click on a project; let's click on Manage NuGet Package and type analyzer in the search input.
- We see all the available analyzers, then select and install the package, CodeCracker.CSharp.
- We can also find it by going to Menu | Tools | Extensions and Updates and searching CodeCracker.CSharp.
data:image/s3,"s3://crabby-images/fcac6/fcac6546a778c3e750197c781f1f16349d956578" alt=""
-
- Now, when we write code and it doesn't respect one of the rules of the analyzer, we will have warnings on the code and suggestions to correct it.
-
- Code Analysis can be enabled on build in our projects. Right-click on the Solution Explorer, root of the project, Properties | Code Analysis and check Enable Code Analysis on Build:
data:image/s3,"s3://crabby-images/2b78b/2b78b1974a3516a2fd5da4b0ccc9841c74424243" alt=""
- Use LINQ and Lambdas in Immediate Window:
-
- Immediate Window appears when selecting the VS menu Debug | Windows | Immediate:
data:image/s3,"s3://crabby-images/063a9/063a9652d0ddfb005df63fa79471cb3697074213" alt=""
-
- We can access object lists or specific variables using the LINQ or Lambdas expression in this bottom window while debugging, by typing LINQ or Lambdas expressions in it.
- We can type a LINQ expression and see its result in the Immediate Window:
data:image/s3,"s3://crabby-images/ab273/ab273492aedfc24e8fe68eb4c15de1f3a7cfa8e2" alt=""
- Perfprmance tips:
We can get performance information in a tooltip, for example:
-
- Create one breakpoint at the beginning of a method
- Create another breakpoint at the end of the method
-
When debugging, we will see, at the second breakpoint, the elapsed time in milliseconds between the first and the second breakpoint:
- Diagnostic Tools:
-
- Diagnostic Tools displays some metrics when you are debugging your application.
- The timeline section indicates events and elapsed time during a debugging session.
- The memory section shows us real-time memory usage (the real one watching private bytes). We also have the ability to take a memory snapshot. The CPU section shows real-time CPU usage:
data:image/s3,"s3://crabby-images/b2bc8/b2bc86dbe9193613a98668ba55257ba99a4190ba" alt=""
We can also view the content of the heap:
data:image/s3,"s3://crabby-images/114fd/114fdc17b406e71c9957f732dc3fcf35d7a11c81" alt=""
- Code lens:
Code lens is a new VS 2017 feature which gives us real-time indications about our code in references, unit tests, and code changes. These pieces of information appear above the method names:
-
- Passing the mouse over references, we can see information about where this method is called from:
data:image/s3,"s3://crabby-images/5cc45/5cc45841d9ca853d45f54cc5cc95d3c184a184dd" alt=""
-
- The second item shows who the last developer that updated this class was:
data:image/s3,"s3://crabby-images/d08d2/d08d28a55b22402a7d20ccc0baf51037223219ec" alt=""
-
- The third one shows code changes and collaboration information:
data:image/s3,"s3://crabby-images/d341d/d341d2f24aec56c2f83a8fb70c7b5e023c3d7593" alt=""
- VS 2017 fixes errors for you:
With Visual Studio 2017, we fix coding errors on the fly while writing code:
-
- We can right-click and select Quick Actions... if the little bulb doesn't appear on the left side of our code:
data:image/s3,"s3://crabby-images/e66a3/e66a3ba88c15649c52e077dbbcf9c578ab669577" alt=""
-
- We right-click on the code highlighted in red:
data:image/s3,"s3://crabby-images/9072f/9072f7ce999794c4d11fde253841300b2a24b6a3" alt=""
The Quick Actions... menu offers a number of possible actions, depending on the context.
-
- It also offers some solutions to implement:
data:image/s3,"s3://crabby-images/ee9bb/ee9bbb242e98baa28d320a4bf4c644dc0cc66381" alt=""