- ASP.NET Core - Log In and Log Out
- ASP.NET Core - Create a User
- ASP.NET Core - User Registration
- ASP.NET Core - Identity Migrations
- Identity Configuration
- ASP.NET Core - Authorize Attribute
- ASP.NET Core - Identity Overview
- ASP.NET Core - Razor Edit Form
- ASP.NET Core - Razor Tag Helpers
- ASP.NET Core - Razor View Import
- ASP.NET Core - Razor View Start
- ASP.NET Core - Razor Layout Views
- ASP.NET Core - DBContext
- Setup Entity Framework
- ASP.NET Core - Views
- ASP.NET Core - Action Results
- ASP.NET Core - Attribute Routes
- ASP.NET Core - Routing
- ASP.NET Core - MVC Design Pattern
- ASP.NET Core - Setup MVC
- ASP.NET Core - Static Files
- ASP.NET Core - Exceptions
- ASP.NET Core - Middleware
- ASP.NET Core - Configuration
- ASP.NET Core - Project.Json
- ASP.NET Core - Project Layout
- ASP.NET Core - New Project
- ASP.NET Core - Environment Setup
- ASP.NET Core - Overview
- ASP.NET Core - Home
ASP.NET Core Useful Resources
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
ASP.NET Core - Razor View Start
In this chapter, we will discuss the Razor View Start. The Razor view engine in MVC has a convention where it will look for any file with the name _ViewStart.cshtml and execute the code inside this file. before executing the code inside an inspanidual view.
data:image/s3,"s3://crabby-images/672a8/672a817d9283737433efa204b42bea9f85ee73f5" alt="ViewStart Cshtml"
The code inside the ViewStart file cannot render into the HTML output of a page, but it can be used to remove duppcate code from the code blocks inside the inspanidual views.
In our example, if we want every view to use the Layout view that we have created in the last chapter, we could put the code to set the Layout view inside a ViewStart instead of having the code inside every view.
Example
Let us take a simple example to see how this works. In our apppcation, we don t want every view to specify that its Layout view is _Layout.cshtml. So right-cpck on the Views folder and select Add → New Item.
data:image/s3,"s3://crabby-images/9bf72/9bf724e8f861309b136c3a742bd501a3c0c98645" alt="Layout Cshtml Add New Item"
There is a specific template in ASP.NET MVC for a ViewStart page, so select MVC View Start Page in the middle pane. The most important part here is that this file is named _ViewStart.cshtml. Now cpck on the Add button.
data:image/s3,"s3://crabby-images/3d8f2/3d8f2f8322e47690a4317bf654a1fe8b9f876fab" alt="View Cshtml"
The primary use of a ViewStart file is to set the Layout view.
Let us now go to the Index.cshtml file and cut the Layout pne and then add it to the ViewStart file as shown in the following program.
@{ Layout = "~/Views/Shared/_Layout.cshtml"; }
When the MVC framework goes to render a view, it will see if there Is a ViewStart file somewhere in the folder hierarchy.
We have placed _ViewStart directly into our Views folder. This is going to impact all the views in all the folders that are inside the Views folder, and both the views inside the Home folder, as well as the Shared folder, as well as any other controller folders that we might add in the future.
If we take ViewStart and place it only in the Home folder, then this pttle bit of code would only execute when we are rendering one of those views in the Home folder.
We can even have multiple ViewStart files, so we could have a ViewStart.cshtml here in the Views folder that sets the Layout view for all views.
But if we wanted to change that default for all of the views just in the Home folder, we could have another ViewStart in the Home folder that sets the layout to something else.
Let us save all the files and run the apppcation.
data:image/s3,"s3://crabby-images/12737/127370519ff606593ade2b1e5b9add42a5707fed" alt="ViewStart File"
You will see that your home page still renders just the way it did before, and we still have the Layout view in effect.
Advertisements