c# - 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。我现在想不通的是为什么参数没有从我上面的代码中得到。请帮忙,我是这个框架的新手。
解决方案
您尝试发送“productVMList”以查看,但您将 categoryVM 模型添加到 html 页面。我认为您应该发送“categoryVMList”而不是“productVMList”,或者您应该将productVM 添加到您的视图中。喜欢;
@model IEnumerable<OpabidFarmsLtd.Models.ViewModels.Shop.ProductVM>
此外,您应该使用 .Add 将新项目添加到列表中。例如,
ProductVMList.Add(object)
否则,将断点置于return View(ProductVMList)
并检查列表为空或已填充。
推荐阅读
- python - 为自定义类赋值
- javascript - 我想移动多个数组列表中的元素
- c++ - 如何使用 mingw 使 g++ 命令在 VSCode 中工作
- javascript - 为什么不是单个表单元素在控制器中没有返回值?
- reactjs - 在 react redux 应用程序中手动导航时状态丢失
- ios - 在 iPhone 5s 上合并音频到视频的问题
- html - 使用 NODE.JS 和 html5 的低延迟(50 毫秒)视频流
- c# - C# CIL stloc.1 问题
- javascript - 如何随着进度条的增长而改变它的颜色
- wordpress - 我在上传文件夹中的文件刚刚获得 IIS_USER 的特殊权限