无法将带有[]的索引应用于类型的表达式

时间:2013-03-24 03:43:41

标签: c# asp.net-mvc foreach

我有这个简单的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

1 个答案:

答案 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>