Creating the ViewModel:

The first step is to create a ViewModel which will represents the elements on the View. Our ViewModel revolves around the relationship between the category and products. The user will select a category from a dropdownlist which will populate all the corresponding products in another dropdownlist. The implementation bellows shows the ArticleEditViewModel:

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Web;
using System.Web.Mvc;
namespace MvcApplication1.ViewModels
{
    public class ArticleEditViewModel
    {
        private List<SelectListItem> _categories = new List<SelectListItem>();
        private List<SelectListItem> _products = new List<SelectListItem>();
        [Required(ErrorMessage = "Please select a category")]
        public string SelectedCategory { get; set; }
        [Required(ErrorMessage = "Please select a product")]
        public string SelectedProduct { get; set; }
        public List<SelectListItem> Products
        {
            get { return _products;  }
        }
        public List<SelectListItem> Categories
        {
            get
            {
                _categories.Add(new SelectListItem(){ Text = "Ruby", Value = "1"});
                _categories.Add(new SelectListItem(){ Text = "JavaScript",Value="2"});
                return _categories;
            }
        }
    }
}

As, you can see that to keep the demo simple we have hard-coded the categories. In the next section we will demonstrate how to populate the categories dropdownlist using the ArticleEditViewModel.

Populating Categories DropDownList:

The Index action of the HomeController returns the new ArticleEditViewModel to the view. The view uses the Categories property of the ArticleEditViewModel to populate the dropdownlist. The Index action is shown below:

public ActionResult Index()
       {             

           return View(new ArticleEditViewModel());
       }

The DropDownList is populated using the code below:

<text>Select a category: </text> @Html.DropDownListFor(x => x.SelectedCategory, new SelectList(Model.Categories,"Value","Text"),"Please Select a category") 
@Html.ValidationMessageFor(x => x.SelectedCategory) 

The DropDownList is bind to the SelectedCategory property of the ViewModel. The SelectedCategory property is also decorated with the [Required] attribute which makes sure that the SelectedCategory is not left blank or on the default item. The screenshot below shows the validation being fired when the Categories DropDownlist is left at the default option and the view is submitted.



The validation is fired because the default option "Select a category" does not have any value associated with it. ASP.NET MVC framework tries to bind the empty string with the SelectedCategory property but fails since the SelectedCategory is marked with [Required] attribute.  
 
Fetching the Products and Populating the Dependent DropDownList:

Our next task is to get the selected category and then fetch the associated products using the categoryId. This will be performed by an ajax call using our beloved jQuery library. The implementation below shows the details.

<script language="javascript" type="text/javascript">
    $(document).ready(function () {
        $("#SelectedCategory").change(function () {
            $.get('/Home/GetProductsForCategory/' + $(this).val(), function (response) {
                var products = $.evalJSON(response);
                var ddlSelectedProduct = $("#SelectedProduct");
                // clear all previous options 
                $("#SelectedProduct > option").remove(); 
                // populate the products 
                for (i = 0; i < products.length; i++) {
                    ddlSelectedProduct.append($("<option />").val(products[i].Value).text(products[i].Text));
                }
            });
        });
    });
</script>

The code above calls the GetProductsForCategory action with the categoryId as the input parameter. The GetProductsForCategory returns the JSON response which represents the products. Before populating the DropDownList with the products we clear all the items in the DropDownList. The GetProductsForCategory action is implemented below:

 public string GetProductsForCategory(string id)
        {
           // get the products from the repository 
            var products = new List<SelectListItem>();
            if (id == "1")
            {
                products.Add(new SelectListItem() {Text = "Introduction to Ruby", Value = "1"});
                products.Add(new SelectListItem() {Text = "Ruby Unit Testing", Value = "2"});
            }
            else if(id == "2")
            {
                products.Add(new SelectListItem(){ Text = "JavaScript testing",Value = "1"});
                products.Add(new SelectListItem() { Text = "JavaScript Ninja", Value = "2"});
            }
            return new JavaScriptSerializer().Serialize(products); 
        }

The above action simply returns the hard-coded values but in actual application you will retrieve the products from a data storage system.

The screenshot below shows the final result:



Reasons why you must trust ASPHostPortal.com

Every provider will tell you how they treat their support, uptime, expertise, guarantees, etc., are. Take a close look. What they’re really offering you is nothing close to what ASPHostPortal does. You will be treated with respect and provided the courtesy and service you would expect from a world-class web hosting business.


You’ll have highly trained, skilled professional technical support people ready, willing, and wanting to help you 24 hours a day. Your web hosting account servers are monitored from three monitoring points, with two alert points, every minute, 24 hours a day, 7 days a week, 365 days a year. The followings are the list of other added- benefits you can find when hosting with us:

- DELL Hardware
Dell hardware is engineered to keep critical enterprise applications running around the clock with clustered solutions fully tested and certified by Dell and other leading operating system and application providers.
- Recovery Systems
Recovery becomes easy and seamless with our fully managed backup services. We monitor your server to ensure your data is properly backed up and recoverable so when the time comes, you can easily repair or recover your data.
- Control Panel
We provide one of the most comprehensive customer control panels available. Providing maximum control and ease of use, our Control Panel serves as the central management point for your ASPHostPortal account. You’ll use a flexible, powerful hosting control panel that will give you direct control over your web hosting account. Our control panel and systems configuration is fully automated and this means your settings are configured automatically and instantly.
- Excellent Expertise in Technology
The reason we can provide you with a great amount of power, flexibility, and simplicity at such a discounted price is due to incredible efficiencies within our business. We have not just been providing hosting for many clients for years, we have also been researching, developing, and innovating every aspect of our operations, systems, procedures, strategy, management, and teams. Our operations are based on a continual improvement program where we review thousands of systems, operational and management metrics in real-time, to fine-tune every aspect of our operation and activities. We continually train and retrain all people in our teams. We provide all people in our teams with the time, space, and inspiration to research, understand, and explore the Internet in search of greater knowledge. We do this while providing you with the best hosting services for the lowest possible price.
- Data Center
ASPHostPortal modular Tier-3 data center was specifically designed to be a world-class web hosting facility totally dedicated to uncompromised performance and security
- Monitoring Services
From the moment your server is connected to our network it is monitored for connectivity, disk, memory and CPU utilization – as well as hardware failures. Our engineers are alerted to potential issues before they become critical.
- Network
ASPHostPortal has architected its network like no other hosting company. Every facet of our network infrastructure scales to gigabit speeds with no single point of failure.
- Security
Network security and the security of your server are ASPHostPortal’s top priorities. Our security team is constantly monitoring the entire network for unusual or suspicious behavior so that when it is detected we can address the issue before our network or your server is affected.
- Support Services
Engineers staff our data center 24 hours a day, 7 days a week, 365 days a year to manage the network infrastructure and oversee top-of-the-line servers that host our clients’ critical sites and services.