所以我有一个模型,其中包含可根据用户自定义的元数据项列表。
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中,名称和标签将是相同的。如果有人可以提供帮助,我们将不胜感激。
答案 0 :(得分:2)
当lambda语法过于复杂时,您可以切换到使用Html.Raw
。此外,您似乎对索引存在"modified closure"问题,因为运行时正在尝试使用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