Introduction to Areas

In this article, we will learn the concept of Areas and how to use it with a practical scenario in ASP.NET MVC 4.

By convention in ASP.NET MVC project template, to separate application code based on responsibilities, we have top level folders as Controllers, Views, and Models. In Controllers folder we can have several controllers, each of them is focused on specific group of functionalities. Inside top level Views folder, there are folders, corresponding to controllers (having the same name), and containing views files for the controller. Corresponding to Action names in controller, we have view files (.cshtml file) in it. Finally in top level Models folder we have models which manages the behaviour and data for the application domain.

This approach works well for small applications having less number of controllers and views. As the number of controllers and views grow, we feel the need of grouping the controllers and views. For large applications, we often face such problem to organize the code effectively. In such cases, Areas help us to organize the code.

Areas are logical grouping of Controller, Models and Views and other related folders for a module in MVC applications. By convention, a top Areas folder can contain multiple areas. Using areas, we can write more maintainable code for an application cleanly separated according to the modules.

Debate on Alternate Approach

Few people can argue that instead of using Area to divide the code as per modules in application, we can make folders structure in top level Controllers/Models/Views folders. As shown below:

But using such approach for divisions, we may face the following problems in large applications:

  1. The nature of functionality of modules may be different (there would be less scope of shared code) and you may need to categorize CSS, scripts, models and other related functionalities for modules too. You have to create the same folder structure in every top level folder that mean inside Views, Models, Scripts, and Images, etc.
  2. There may be name conflict for controller if modules need to have the controllers with same name. For example, many modules in application may like to have its own Home Controller.
  3. The code of specific module will be more scattered (in comparison to the case of using Area approach for the modules)

So Area provides a better way to separate the code for modules in a much elegant way. We can keep all the specific resources needed for a module in its Area. The reusable and shared resource can be put inside corresponding top level folders in the ASP.NET MVC application. In the next section, we will see how to use Areas in real time application.

How to Avoid Name Conflict

Let's say if there is an area called "Payment" and it is having a "PaymentController". In such cases while using Areas, we need to remember the following three points in case Controller and Area is having the same name:

  1. In Global.asax.cs file, under the Application_Start method AreaRegistration. RegisterAllAreas method must be called in the first place.
  2. In RouteConfig.cs file, under the RegisterRoutes method you must declare namespace to avoid the conflict between same controllers name.
  3. In MenAreaRegistration.cs file, under RegisterArea method you must declare namespace to avoid the conflict between same controllers name.

For another such example, please have a look at this question/answer on stackoverflow. The above steps will be more clear after code walkthrough given below for demo application.

Overview of Demo Application

Usually an e-commerce application has various kinds of products divided into many categories. Each product contains various kinds of information about a product like manufacturing details, availability, price, offers if any, etc. In such kinds of scenarios, it is better to divide the application module using Areas.

Here for demo, we will develop a simple sample of shopping application. Application will be divided into three modules called Home, Men and Women. As per general scenario, Men and Women are main categories having their own sub categories as shown in the below figure.

  • Home: This module will have general information about the application. This is implemented using default controller/views, etc. available with project template. No use of area concept here as it provides face to entire application by having home page and standard information.
  • Men: This module will have information about the products for Men. This is implemented using Area concept. We created a "Men" area inside "Areas" top level folder. It has all sub-module and specific home page for "Men" module.
  • Women: This module will have information about the products for Women. It is also implemented using Area and similar to "Men" module.

Note:

  • In the demo, we will focus only on how to use Areas, so I have used same CSS and dummy data. But in real world application, display requirement in different module may be very specific.
  • All common CSS files, JS files and images are placed in top level Content folder as shown below:

  • To understand this article better, please download the attached code, have an overview of the code, then follow the steps given in this article.

Final Output: Final output of this sample application will look as shown below:

Creating Demo Application

Let's get started by firing up Visual Studio 2012 and follow the below steps:

  1. Create a new Project by selecting ASP.NET MVC4 Web Application template and give it project name as AreaDemo and click OK.

  2. Select a template as Basic application then click OK. Visual Studio adds AreaDemo project in solution as shown below in screenshot.

  3. First, we will create the header and menu of application. Please get the required CSS, JavaScript and images from downloaded code.
  4. Few references are required in _Layout.cshtml file as shown below:
    Hide   Copy Code
    <script src="~/Scripts/jquery-1.8.2.min.js"></script>
  5. Modify the code in _Layout.cshtml file in Shared folder as written below. It will provide common layout (Header and Menu) for all screens.
    Hide   Shrink   Copy Code
    <body>
    <div id="container">
    <header id="pageHeader">
    <img src="~/Content/images/header.jpg" />
    <nav>
    <ul>
    <li><a href="http://www.codeproject.com/">Home</a></li>
    <li><a href="~/Men/Home/Index">Men</a>
    <ul>
    <li><a href="~/Men/Clothing/Index">Clothing</a></li>
    <li><a href="~/Men/Footwear/Index">Footwears</a></li>
    </ul>
    </li>
    <li><a href="~/Women/Home/Index">Women</a>
    <ul>
    <li><a href="~/Women/Clothing/Index">Clothing</a></li>
    <li><a href="~/Women/Footwear/Index">Footwears</a></li>
    </ul>
    </li> </ul>
    </nav>
    </header>
    <br />
    <br />
    <div id="pageContainer">
    @RenderBody() </div>
    </div>
    </body>
  6. So far Menu is created. But if we click on link in menu, nothing would happen because we have not created Areas yet.
  7. Right click on project (AreaDemo) in solution explorer, go to add and click on Areas options as shown below:

    Areas folder will be added to your project. This top level Areas folder is supposed to have areas by convention. Each area has its own Models, Views, Controllers and areaRegistration.cs. areaRegistration.cs file is used to configure the routes for the area.

  8. Add an Area by right clicking on Areas folder you just created and give name to new area as Men (Men is module name). Men Area folder is being added to your project as shown below:

    In the above screenshot, Controllers, Models, Views folders and MenAreaRegistration.cs file are being added by Visual Studio. Content folder added by me to have all images required for Men module (get the images from downloaded code). Men module may have sub modules as we have for Men’s Clothing and another for Footwear.

  9. Let us implement Men -> Clothing module. Add three class files under the Models folder as shown below:

    Write the following code in MenClothing.cs file:

    Hide   Copy Code
    public class MenClothing
    {
    public int Id { get; set; }
    public string Name { get; set; }
    public int Size { get; set; }
    public double Price { get; set; }
    public string imageURL { get; set; }
    }

    Write the following code in MenFootwear.cs file:

    Hide   Copy Code
    public class MenFootwear
    {
    public int Id { get; set; }
    public string Name { get; set; }
    public int Size { get; set; }
    public double Price { get; set; }
    public string imageURL { get; set; }
    }

    Write the following code in MenRepository.cs file:

    Hide   Shrink   Copy Code
    public class MenRepository
    {
    public List<MenClothing> GetCloths()
    {
    List<MenClothing> result = new List<MenClothing> {
    new MenClothing () { Id = 1, Name = "Formal Shirt",
    Size= 40, Price = 1200, imageURL="/Areas/Men/Content/images/men_cloths/img_c1.jpg"},
    new MenClothing () { Id = 2, Name = "Jeans Pant",
    Size= 36, Price = 2200, imageURL="/Areas/Men/Content/images/men_cloths/img_c2.jpg"},
    new MenClothing () { Id = 3, Name = "Casual Shirt",
    Size= 40, Price = 1000, imageURL="/Areas/Men/Content/images/men_cloths/img_c3.jpg"},
    new MenClothing () { Id = 4, Name = "Formal Pant",
    Size= 36, Price = 1299, imageURL="/Areas/Men/Content/images/men_cloths/img_c4.jpg"}
    }; return result;
    } public List<MenFootwear> GetFootwears()
    {
    List<MenFootwear> result = new List<MenFootwear>
    {
    new MenFootwear () { Id = 1, Name = "Casual Slipper", Size= 8,
    Price = 1200, imageURL="/Areas/Men/Content/images/men_footwears/img_f1.jpg"},
    new MenFootwear () { Id = 2, Name = "Casual Slipper", Size= 9,
    Price = 2200, imageURL="/Areas/Men/Content/images/men_footwears/img_f2.jpg"},
    new MenFootwear () { Id = 3, Name = "Casual Shoes", Size= 9,
    Price = 2500, imageURL="/Areas/Men/Content/images/men_footwears/img_f3.jpg"},
    new MenFootwear () { Id = 4, Name = "Formal Shoes", Size= 9,
    Price = 1600, imageURL="/Areas/Men/Content/images/men_footwears/img_f4.jpg"}
    }; return result;
    }
    }

    The above code snippet is very simple and self-explanatory so hope you can understand it easily.

  10. Add a controller under the Controllers folder named as Clothing inside Men Area as shown below:

    Write the following code inside the Index method in ClothingController.cs file.

    Hide   Copy Code
    public ActionResult Index()
    {
    MenRepository menRepository = new MenRepository();
    var cloths = menRepository.GetCloths();
    return View(cloths);
    }

    Index is an action method that will return a view having MenClothing model which has list of all clothes for Men.

  11. Right click on Index action method (in ClothingController.cs) to add a view and follow the default options. It will add Index.cshtml file inside Views > Clothing folder. Write the following code in Index.cshtml view. This view will use MenClothing Model as shown below:
    Hide   Shrink   Copy Code
    @model IEnumerable<AreaDemo.Areas.Men.Models.MenClothing>
    @{
    Layout = "~/Views/Shared/_Layout.cshtml";
    } <h3 > Men Clothings</h3> <table class="tblStyle">
    <tr class="tblHearerRow">
    <th class="tblHearerCell">Product
    </th>
    <th class="tblHearerCell">Price
    </th>
    <th class="tblHearerCell">Size
    </th>
    <th class="tblHearerCell">Images
    </th> </tr>
    @foreach (var item in Model)
    {
    <tr class="tblRow">
    <td class="tblColumn">
    @Html.DisplayFor(modelItem => item.Name)
    </td>
    <td class="tblColumn">
    @Html.DisplayFor(modelItem => item.Price)
    </td>
    <td class="tblColumn">
    @Html.DisplayFor(modelItem => item.Size)
    </td>
    <td class="tblColumn">
    <div class="thumbnail-item">
    <a href="#">
    <img src="@item.imageURL" class="thumbnail" />
    </a>
    <div class="tooltip">
    <img src="@item.imageURL"
    alt="" class="imageShadow" />
    <span class="overlay"></span>
    </div>
    </div>
    </td>
    </tr>
    } </table>

    The above table will display the products under clothes category for men.

  12. Open Global.asax.cs file and inside the Application_Start method. It must be having "AreaRegistration.RegisterAllAreas();". Verify this method is having such code:
    Hide   Copy Code
    protected void Application_Start()
    {
    AreaRegistration.RegisterAllAreas(); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    }
  13. Open MenAreaRegistration.cs file under Areas > Men folder. This file is used to define the routes for a particular module/Area. Add the following line of code in MapRoute method as shown below:
    Hide   Copy Code
    namespaces: new[] { "AreaDemo.Areas.Men.Controllers" }

    Finally RegisterArea methods must look like shown below:

  14. Open RouteConfig.cs file under App_Start folder and add the following line of code inside RegisterRoutes method as shown below:
    Hide   Copy Code
    namespaces: new[] { "AreaDemo.Controllers" }

    Final RegisterRoutes method looks like shown below:

  15. Add another controller to Controllers folder under the Men (Area) module named as FootwearController (as we done for Clothing Controller). Write the following code as shown below:
    Hide   Copy Code
    public ActionResult Index()
    {
    MenRepository menRepository = new MenRepository();
    var footwears = menRepository.GetFootwears();
    return View(footwears);
    }
  16. Right click on Index action method (in FootwearController.cs) to add a view and follow the default options. It will add Index.cshtml file inside Views > Footwear folder. This view will display all footwear for men. Write the following code in Index.cshtml file as shown below:
    Hide   Copy Code
    @model IEnumerable<AreaDemo.Areas.Men.Models.MenFootwear>
    
    @{
    Layout = "~/Views/Shared/_Layout.cshtml";
    }
    <h3> Men Footwears</h3>
  17. Add one more controller to Controllers folder under the Men (Area) module named as HomeController. It will be specific home page for Men Module. Write the following code as shown below:
    Hide   Copy Code
    public ActionResult Index()
    {
    return View();
    }
  18. Right click on Index action method (in HomeController.cs just created) to add a view and follow the default options. It will add Index.cshtml file inside Views > Home folder. Write the following code in this file as shown below:
    Hide   Copy Code
    @{
    Layout = "~/Views/Shared/_Layout.cshtml";
    } <div id="homeDiv">
    <h2>This is home page for Men module.
    To view the products in Men module, please select a category from top menu.
    </h2>
  19. Now run the application and click on Clothing under the Men module. Hope you will get the following screen.

    p

  20. Now click on Footwear under the Men module. Hope you will get the following screen.

  21. To implement the women Module, follow the same step from 6 to 20 steps with different data and images. In case of any confusion, look into the downloaded code having both modules implemented.

Conclusion

In this article, we learned how to use Areas in ASP.NET MVC application. It is a very helpful concept to organize big applications in an elegant way. Your queries and comments are most welcome in this respect. Thanks.

Areas in ASP.NET MVC 4的更多相关文章

  1. 使用Areas分离ASP.NET MVC项目

    为什么需要分离? 我们知道MVC项目各部分职责比较清晰,相比较ASP.NET Webform而言,MVC项目的业务逻辑和页面展现较好地分离开来,这样的做法有许多优点,比如可测试,易扩展等等.但是在实际 ...

  2. (转)ASP.NET Mvc 2.0 - 1. Areas的创建与执行

    转自:http://www.cnblogs.com/terrysun/archive/2010/04/13/1711218.html ASP.NET Mvc 2.0 - 1. Areas的创建与执行 ...

  3. 1.开始学习ASP.NET MVC

    Hello,大家好! 好久没有开始记录博客了,是时候开始分享一下了,这个系列主要为零基础的同学,量身打造的.废话不多说,我们开干! 什么是ASP.NET MVC MVC(Model-View-Cont ...

  4. ASP.NET MVC 4 WebAPI. Support Areas in HttpControllerSelector

    This article was written for ASP.NET MVC 4 RC (Release Candidate). If you are still using Beta versi ...

  5. ASP.NET MVC 及 Areas 简单控制路由

    ASP.NET MVC中怎么去控制路由,这个想关的文章很多,我在这里就是自我总结一下,仅供参考. 1.我们新建一个项目,查看RouteConfig.cs,代码如下: public static voi ...

  6. 5. ASP.NET MVC 中的Areas【区域】是什么

    [PS返回上一篇:-->4.ASP.NET MVC 5.0 视图之模型绑定] 从ASP.NET MVC 2.0开始,微软就提供了一个新特性:Areas[区域].Areas仅仅是用来将大型程序拆分 ...

  7. ASP.NET MVC Areas View 引用 外部母版视图

    ASP.NET MVC Area => Areas View 引用 外部母版视图 创建项目:MVCSite.Area 创建mvc area 1.Areas View 引用 外部母版视图 1.1 ...

  8. ASP.NET MVC使用Areas后怎样获取Area(区域)的名称

    写此随笔,目的只为今后在ASP.NET MVC项目中再用到Area(区域)时作为备查. 获取当前Area(区域)名称的方法是: ViewContext.RouteData.DataTokens[&qu ...

  9. 【Pro ASP.NET MVC 3 Framework】.学习笔记.12.ASP.NET MVC3的细节:URLs,Routing和Areas

    Adam Applied ASP.NET 4 in Context 1 介绍Routing系统 在引入MVC之前,ASP.NET假定被请求的URLs和服务器硬盘上的文件之间有着直接关系.服务器的任务是 ...

随机推荐

  1. php中生成树形菜单

    废话不多说!上代码 class tree { /** * 生成树型结构所需要的2维数组 * @var array */ var $arr = array(); /** * 生成树型结构所需修饰符号,可 ...

  2. WMS专业名词解释

    1.摘果:按照单一客户上订单的内容进行拣选货品(即去货位上拣货),拣选完成后即可直接进行质检.包装. 2.播种:将多个客户订单上的货品进行汇总,然后对这些货品进行拣选.拣选完成后,再区分出每一个客户的 ...

  3. poj3107(dfs,树形dp)

    和poj1655的方法完全一样,但是这道题的n的范围大了,用vector存图会TLE(poj没有O2编译优化),所以改用前向星来存图就可以了.. 有关树的重心,看这里:poj1655 这里解释一下前向 ...

  4. MarkDown小技巧

    MarkDown编辑 MarkDown编辑的时候,可以直接插入HTML的编辑手法. 例如如果想要将一段话中的某一个或者某几个字设为其他颜色,但又不想将这几个字与这段话分割的时候,可以这样 你可以这样将 ...

  5. Java进阶知识点4:不可变对象与并发 - 从String说起

    一.String的不可变特性 熟悉Java的朋友都知道,Java中的String有一个很特别的特性,就是你会发现无论你调用String的什么方法,均无法修改this对象的状态.当确实需要修改Strin ...

  6. linux【基础命令】

    最近在学linux,避免一些命令忘记,所以在此记录一下: linux文件列表遍历 ls -a 列出所有的文件及文件夹 包括隐藏的ls -l 列出文件目录的详细信息 history 查看历史命令ctrl ...

  7. phpcms URL修改

    修改caches\configs\system.php中'html_root' => 'html',//生成静态文件路径改成'html_root' => '',//生成静态文件路径,然后修 ...

  8. Supervisor进程监控

    安装 yum install -y python-setuptools easy_install supervisor echo_supervisord_conf > /etc/supervis ...

  9. gitlab pipelines 使用

    1. 安装runner   # For Debian/Ubuntu curl -L https://packages.gitlab.com/install/repositories/runner/gi ...

  10. 两种方式创建Maven项目【方式一】

    经常使用maven进行项目的管理,今天整理两种方式创建maven项目及创建过程中碰到的问题怎么解决: 方式一: 1.新建maven项目,点击下一步. 2.勾选Create a simple proje ...