如何在视图页面中使用foreach
本文关键字:foreach 视图 | 更新日期: 2023-09-27 18:16:37
试图将已确认的订单列表传递到供应商页面(通过断点检查列表已经过),只是在使用foreach在视图中显示列表时出现问题。
//SupplierController
public ActionResult Index()
{
BuyABicycle_Entities db1 = new BuyABicycle_Entities();
IEnumerable<BicycleOrder> All_Orders = (from c in db1.BicycleOrders
where c.Id >= 1
select c).ToList();
SupplierVM model = new SupplierVM { allOrders = All_Orders };
return View(model);
}
//SupplierVM
public class SupplierVM
{
public IEnumerable<BicycleOrder> allOrders { get; set; }
}
Views/Supplier/Index
@model BicycleShop.ViewModels.SupplierVM
@{
ViewBag.Title = "Supplier";
//var orders = (IList<BicycleOrder>) Model.;
// var orders = (List<BicycleOrder>) Model.Order);
}
@using (Html.BeginForm())
{
<table>
@foreach (var _Order in Model.allOrders)
{
<text>
<tr>
<td>@_Order.CustomerName</td>
</tr>
</text>
}
</table>
<input type="submit" />
}
这抛出了@foreach (var _Order in Model.allOrders)的错误编译器错误消息:CS0012:类型'IdeaBlade.EntityModel。"实体"在未引用的程序集中定义。必须添加对程序集"IdeaBlade"的引用。EntityModel, Version=6.1.7.0, Culture=neutral, PublicKeyToken=287b5094865421c0'.
Foreach循环的表在MVC4我是否需要在顶部为列表声明一个变量,然后遍历
感谢任何帮助。由于
您的视图将模型指定为IEnumerable<SupplierVM>
。因此,要遍历订单,首先必须遍历供应商:
@foreach (var supplier in Model)
{
foreach (var order in supplier.allOrders)
{
...
}
}
然而,似乎你实际上并没有传递许多SupplierVM
实例,但只有一个。因此,您应该将视图的模型更改为:
@model BicycleShop.ViewModels.SupplierVM
然后,你可以直接遍历顺序:
@foreach (var order in Model.allOrders)
{
...
}
也许razor混淆了HTML和代码:
试试这个:
@foreach (var _Order in Model)
{
<text>
<tr>
<td>@Html.TextBoxFor(x => x.allOrders)</td>
<td>@_Order.allOrders</td>
@<td>@Html.TextBoxFor(x => x.CustomerName, new { @readonly = true }) </td>
@foreach(var item in _Order)
{
item.ItemProp <br />
}
</tr>
</text>
}
里面的{}
剃刀期待它所有的代码,如果你想把HTML在那里-多行使用<text></text>
为一行使用@: