3

所以我有一个模型,其中包含每个用户可定制的元数据项列表。

public class MyModel {
    public int ID { get; set; }
    public String Name { get; set; }
    public DateTime Created { get; set; }

    // Need to diplay each as a column
    public List<MetaData> Data { get; set; }
}
public class MetaData {
    public int ID { get; set; }
    public String Name { get; set; }
    public String Label { get; set; }
    public String Value { get; set; }
}

对于 MyModel 上的每个元数据项,我需要向 WebGrid 添加一个列,其名称为列名,标签为标题,每个 MyModel 输出的值。

@{
    WebGrid grid = new WebGrid(source: Model, rowsPerPage: 5, canPage: true);

    List<WebGridColumn> cols = new List<WebGridColumn>();
    cols.Add(grid.Column("Name", "Name"));
    cols.Add(grid.Column("Created"));
    for (int i = 0; i < Model.FirstOrDefault().Data.Count; i++)
    {
        cols.Add(grid.Column(Model.FirstOrDefault().Data[i].Name, Model.FirstOrDefault().Data[i].Label,
            format: item => @<text>@item.Data[i].Value</text>
        ));
    }
}

@grid.GetHtml(
    tableStyle: "table",
    htmlAttributes: new { id = "MyGrid" },
    columns: cols)

元数据列在所有 MyModel 之间共享,因此每个都不会有一组新的列。名称和标签在不同的 MyModel 中将是相同的。如果有人可以提供帮助,将不胜感激。

4

1 回答 1

2

当 lambda 语法变得过于复杂时,您可以切换到使用Html.Raw. 此外,您似乎对索引有一种“修改后的闭包”问题,因为运行时正在尝试使用的最后一个值i——您可以通过制作i. 这对我有用:

for (int i = 0; i < Model.First().Data.Count; i++)
{
    int local = i;
    cols.Add(grid.Column(Model.First().Data[i].Name, Model.First().Data[i].Label, 
        format: item => Html.Raw("<text>" + item.Data[local].Value + "</text>")
    ));
}

编辑

破解“格式” lambda ...这显然也有效:

format: item => @item.Data[local].Value
于 2013-08-19T18:29:35.620 回答