我在视图中遇到从不同实体提取数据的问题。基本上,我有一个桥接实体CategoryProducts,它将Category和产品数据结合在一起。我最终想要显示的是产品列表以及每个产品 - 它们的类别。但是,我完全坚持如何使最后一部分 - 显示类别 - 发生。
这是我模型的代码 -
public class Product
{
public int ProductId { get; set; }
public string Title { get; set; }
public virtual ICollection<CategoryProduct> CategoryProducts { get; set; }
}
public class CategoryProduct
{
public int CategoryProductID { get; set; }
public int CategoryId { get; set; }
public int ProductId { get; set; }
public virtual Product Product { get; set; }
public virtual Category Category { get; set; }
}
public class Category
{
public int CategoryId { get; set; }
public string Title { get; set; }
public virtual ICollection<CategoryProduct> CategoryProducts { get; set; }
}
我的控制器非常简单,它只是将该桥接实体推送到视图:
public ActionResult Index()
{
return View(db.CategoryProducts.ToList());
}
最后,我的视图显示产品和类别,但现在它只是为同一产品创建额外的行,如果它具有不同的类别,例如产品 1:类别 1,产品 1:类别 2 等等。我想去的地方是产品1:类别1,类别2。
@model IEnumerable<ProductsCode.Models.CategoryProduct>
<h2>Index</h2>
<table>
<tr>
<th>Title</th>
<th>Category</th>
</tr>
@foreach (var item in Model) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.Product.Title)
</td>
<td>
@foreach (var categories in item)
{
@Html.DisplayFor(modelItem => item.Why.Title)
}
</td>
</tr>
}
</table>
错误: 编译器错误消息: CS1579: foreach 语句无法对类型为"产品代码.模型.类别产品"的变量进行操作,因为"产品代码.模型.类别产品"不包含"GetEnumerator"的公共定义
编辑:添加了另一个foreach循环和错误。
为什么你不能像这样更改视图模型
public class MyProduct
{
public int ProductId { get; set; }
public string Title { get; set; }
public virtual ICollection<Category> CategoryList { get; set; }
}
和视图
@model IEnumerable<ProductsCode.Models.MyProduct>
<h2>Index</h2>
<table>
<tr>
<th>Product</th>
@Html.DisplayFor(modelItem => item.ProductId)
<th>Categories for Product</th>
</tr>
@foreach (var item in Model.CategoryList) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.Title)
</td>
<td>
@Html.DisplayFor(modelItem => item.CategoryId)
</td>
</tr>
}
</table>