Areas in ASP.NET MVC allows us to separate a Web Application into smaller modules and organize the code. For example, if you have a blog feature in your application, you can create that as a separate area and that gives flexibility to maintain the blog code separately.
Steps for Creating an Area in ASP.NET MVC Project
- Create a new ASP.NET MVC Web Application.
data:image/s3,"s3://crabby-images/ce95d/ce95d5a0f46062dc3fc764b6b17864cb5d12128a" alt="image image"
- Choose empty template to start with and click on OK.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Now you should be able to see a solution with ASP.NET MVC web application project.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Right click on the project, click Add and click on Area.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Enter the Area name and click Add.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Area gets created and your solution looks something like below:
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Build your project, right click on Controllers folder of
MainApplication
, click on Add and then click on controller.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Enter the Controller name and click on Add.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Similarly, add Controller to Areas > Blog > Controllers. Your solution should look like below:
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- As you can see, I have two Controllers, one in the Main Application and one in the Area called Blog with the same name
HomeController
. This is possible because both the Controllers have different NameSpaces, i.e., MainApplication.Controllers
and MainApplication.Areas.Blog.Controllers
respectively. - Now that we have Controllers created, right click on Index action and click Add View.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Similarly Add View, to the Blog areas
HomeController
Index action. Your solution should look like below:
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Build your application hitting Ctrl + Shift + B and then hit Ctrl + F5 to run it. When you run it, if you are using the Controller with the same name like I did, i.e.,
HomeController
, you should get the below error.
Multiple types were found that match the controller named 'Home'. This can happen if the route that services this request ('{controller}/{action}/{id}') does not specify namespaces to search for a controller that matches the request. If this is the case, register this route by calling an overload of the 'MapRoute' method that takes a 'namespaces' parameter.
- To fix the above, go to RouteConfig.cs in
App_Start
and Add the namespace as shown below:
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home",
action = "Index", id = UrlParameter.Optional },
<font style="background-color: #ffff00">namespaces: new string[] { "MainApplication.Controllers" }</font>
);
}
- Similarly go to BlogAreaRegistration.cs in Areas > Blog and add namespace as shown below:
public override void RegisterArea(AreaRegistrationContext context)
{
context.MapRoute(
"Blog_default",
"Blog/{controller}/{action}/{id}",
new { action = "Index", id = UrlParameter.Optional },
<font style="background-color: #ffff00">new string[] { "MainApplication.Areas.Blog.Controllers" }
</font> );
}
- By adding namespace to both
RouteConfig
and BlogAreaRegistration
, the error will get fixed, now run the application again and you should see the below output.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Now try to navigate to Blog Home by typing http://localhost:<port>/blog/home in the address bar of the browser.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- For navigating from Main Application to Blog Home, add the below ActionLink in the Main Application > Views > Home > Index.
@Html.ActionLink("Blog Home", "Index", "Home", new { area = "Blog" }, null)
- The above line should render a hyperlink as shown below, by clicking on it will navigate to Blog/Home.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
- Similarly for navigating from Blog Home to Main Application, add the below
ActionLink
in the Main Application > Areas > Blog > Views > Home > Index.
@Html.ActionLink("Home", "Index", "Home", new { area = "" }, null)
- The above line should render a hyperlink as shown below, by clicking on it will navigate to Main Application Home.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="image image"
You can get the source code from https://github.com/arunendapally/BasicMVCArea.