0

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

1 回答 1

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>
于 2013-03-24T03:49:29.940 回答