问题描述
public class Person
{
[display(Name = "A")]
public string PropertyA { get; set; }
[display(Name = "B")]
public string PropertyB { get; set; }
[display(Name = "C")]
public string PropertyC { get; set; }
...
...
[display(Name = "Z")]
public string PropertyZ { get; set; }
}
@model Person
<div>
@foreach(var prop in Model.GetType().GetProperties())
{
// logic to decide if the property should be
// included in the output or not
<div>@prop.Name</div>
}
</div>
这将列出所有属性,每个属性都在自己的 div
中。
我需要做的是输出每个属性的 display
。
类似于通过 []
寻址对象属性的 javascript 方式。即:
<div>@Html.displayNameFor(m => m[prop.Name])</div> //does not work
这是我试过的:
@foreach(var prop in Model.GetType().GetProperties())
{
<div>@Html.displayNameFor(prop.Name)</div> //does not work
}
我的目标是稍后过滤掉视图中不需要的属性,而不必在我决定更改类(通过添加或删除属性)时手动编辑视图。
解决方法
使用 LINQ 识别包含 Display
属性的对象并选择 Name
参数值:
@foreach (var prop in Model.GetType().GetProperties())
{
// TODO: logic to decide if the property should be included in the output or not
foreach (var ca in prop.CustomAttributes)
{
var name = ca.NamedArguments.Where(t => t.MemberName.Equals("Name")).Select(x => x.TypedValue.Value).FirstOrDefault().ToString();
<div>@Html.DisplayName(name)</div>
}
}