在MVC3中排序时,“无法对空引用执行运行时绑定”错误

时间:2012-09-02 07:32:09

标签: .net asp.net-mvc asp.net-mvc-3 c#-4.0 razor

以下是视图代码:

@helper sortLink(string name, int id)
{
<a href="@Url.Action("Products", "Home", new { sortBy = id, isasc = (id ==     ViewBag.sortBy ? !@ViewBag.isAsc : @ViewBag.isAsc).ToString().ToLower() })">@name</a> 
}

<h2 class="center">Products</h2>

<table class="Products">
@* header *@

<tr>
<th>@sortLink("ID",1)</th>
<th>@sortLink("Name",2)</th>
<th>@sortLink("Number", 3)</th>
<th>@sortLink("Color", 4)</th>
<th>@sortLink("Standard Cost", 5)</th>
<th>@sortLink("List Price", 6)</th>
<th>@sortLink("Size", 7)</th>
<th>@sortLink("Weight", 8)</th>
</tr>

这是控制器代码:

  {
    AdventureWorksLT2008R2Entities db = new AdventureWorksLT2008R2Entities();
    const int pageSize = 10;

    [HttpGet]
    public ActionResult Products(int page = 1, int sortBy = 1, bool isAsc = true)
    {
        IEnumerable<Product> products;

        #region sorting
        switch (sortBy)
        {
            case 1:
                products = isAsc ? db.Products.OrderBy(p => p.ProductID) : db.Products.OrderByDescending(p => p.ProductID);
                break;

            case 2:
                products = isAsc ? db.Products.OrderBy(p => p.Name) : db.Products.OrderByDescending(p => p.Name);
                break;

            case 3:
                products = isAsc ? db.Products.OrderBy(p => p.ProductNumber) : db.Products.OrderByDescending(p => p.ProductNumber);
                break;

            case 4:
                products = isAsc ? db.Products.OrderBy(p => p.Color) : db.Products.OrderByDescending(p => p.Color);
                break;

            case 5:
                products = isAsc ? db.Products.OrderBy(p => p.StandardCost) : db.Products.OrderByDescending(p => p.StandardCost);
                break;

            case 6:
                products = isAsc ? db.Products.OrderBy(p => p.ListPrice) : db.Products.OrderByDescending(p => p.ListPrice);
                break;

            case 7:
                products = isAsc ? db.Products.OrderBy(p => p.Size) : db.Products.OrderByDescending(p => p.Size);
                break;

            case 8:
                products = isAsc ? db.Products.OrderBy(p => p.Weight) : db.Products.OrderByDescending(p => p.Weight);
                break;
        }
        #endregion

        products = db.Products
            .OrderBy(p=>p.ProductID)
            .Skip((page - 1) * pageSize)
            .Take(pageSize)
            .ToList();

        ViewBag.CurrentPage = page;
        ViewBag.PageSize = pageSize;
        ViewBag.TotalPages = Math.Ceiling((double)db.Products.Count()/pageSize);

        return View(products);

我正在关注一个教程,并在排序部分发现它一直显示此错误, 我需要你的帮助才能删除错误,请解释一下Sortlink帮助方法的哪些方法,我无法理解它。编写本教程的人在这方面没有解释太多。

1 个答案:

答案 0 :(得分:3)

我猜测问题在于您尝试在视图中使用ViewBag.isAsc,但从未分配过它。此外,在case语句之后,您正在重置products变量,这会使您在case语句中设置的顺序完全无效 - 删除它。所以在看起来应该是这样的:

switch(sortBy) {
    // include all the case statements here as you have them

    // you need to add a default section to make it a valid switch statement
    default:
    break;
}
#endregion

// (remove the products = statement that was here, it's not needed

ViewBag.CurrentPage = page;
ViewBag.PageSize = pageSize;
ViewBag.TotalPages = Math.Ceiling((double)db.Products.Count()/pageSize);

// add these two lines, as required by the View
ViewBag.isAsc = isAsc;
ViewBag.sortBy = sortBy;


return View(products
    .Skip((page - 1) * pageSize)
    .Take(pageSize)
    .ToList()
);