首页 > 解决方案 > sql select语句在asp.net中返回空引用错误

问题描述

我在视图中查看特定类别的项目。我希望它在单击时查看该类别下的所有产品,但我得到一个空引用异常。我对类别和产品有单独的表格。

这是我尝试过的。视图中的代码:

@model IEnumerable<OpabidFarmsLtd.Models.ViewModels.Shop.CategoryVM>

<h3>Categories</h3>

<ul>
<li><a href="#">All</a></li>
@foreach (var item in Model)
{
    <li><a href="/shop/category/@item.Slug.ToLower()">@item.Name</a></li>
}
 </ul>

还有我的控制器(ShopController):

public ActionResult Category(string name)
    {
        // Declare a list of ProductVM
        List<ProductVM> productVMList;


        using (Db db = new Db())
        {
            // Get category id
            CategoryDTO categoryDTO = db.Categories.Where(x => x.Slug == name).FirstOrDefault();
            int catId = categoryDTO.Id;

            // Init the list
            productVMList = db.Procucts.ToArray().Where(x => x.CategoryId == catId).Select(x => new ProductVM(x))
                .ToList();

            // Get category name
            var productCat = db.Procucts.Where(x => x.CategoryId == catId).FirstOrDefault();
            ViewBag.CategoryName = productCat.CategoryName;
        }

        // Return view with list
        return View(productVMList);
    }

错误消息截图

编辑:在寻找问题的同时,我发现方法 Category 根本没有得到参数,我注释了其中的所有代码并这样做:

 public ActionResult Category(string name)
    {
        string cat;
        using (Db db = new Db())
        {
            CategoryDTO dto = db.Categories.Where(x => x.Slug == "test-category").FirstOrDefault();
            cat = dto.Id.ToString();
        }

        return Content(name + cat);
    }

它只返回 8 ,这是数据库中的 Id。我知道它为什么给我null,那是因为它从未收到任何参数,然后默认为null。我现在想不通的是为什么参数没有从我上面的代码中得到。请帮忙,我是这个框架的新手。

标签: c#sqlasp.netasp.net-mvcasp.net-mvc-5

解决方案


您尝试发送“productVMList”以查看,但您将 categoryVM 模型添加到 html 页面。我认为您应该发送“categoryVMList”而不是“productVMList”,或者您应该将productVM 添加到您的视图中。喜欢;

@model IEnumerable<OpabidFarmsLtd.Models.ViewModels.Shop.ProductVM>

此外,您应该使用 .Add 将新项目添加到列表中。例如,

ProductVMList.Add(object)

否则,将断点置于return View(ProductVMList)并检查列表为空或已填充。


推荐阅读