我有这个简单的MVC 4代码。我查询数据库并获取所有结果,然后保存在ViewBag对象中,然后使用foreach循环遍历它们但错误:
无法将带有[]的索引应用于类型为
的表达式
不允许我给他们看。什么我失踪了?
这里是带有entityframework的SQL查询
public ActionResult Index()
{
var ReturnLabelsAndInputsForIndexations = Conexion.MainConexion;
var IndexationForm = ReturnLabelsAndInputsForIndexations.Labels.ToList();
ViewBag.IndexationForm = IndexationForm;
return View();
}
索引视图
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
<table>
@foreach (var Indexacion_Labels in ViewBag.IndexationForm)
{
<tr>
<td>@Indexacion_Labels["LABELS"]//Exception HERE</td>
<td>@GetInputType(Indexacion_Labels["INPUT_TYPE"], Indexacion_Labels["NAME"])</td>
</tr>
}
</table>
</div>
</body>
</html
答案 0 :(得分:1)
ReturnLabelsAndInputsForIndexations.Labels
的类型(无论什么类型)都没有实现indexer。要解决此问题,您需要将其添加到标签的视图模型
public this[string index]
{
get
{
...
}
}
或将您的视图代码更改为类似的内容(假设视图模型的属性存在)
<tr>
<td>@Indexacion_Labels.Labels</td>
<td>@GetInputType(Indexacion_Labels.Input_Type, Indexacion_Labels.Name)</td>
</tr>