我有一个 Dto
类型的对象:
public class ClassA
{
[DataMember(Order = 10)]
public string Code { get; set; }
[DataMember(Order = 20)]
public string Symbology { get; set; }
[DataMember(Order = 30)]
public string Category { get; set; }
public string NonMemberPropertyA { get; set; }
}
我有兴趣获取所有 DataMember
装饰属性:
var propertyInfos = type.GetProperties().Where(p => Attribute.IsDefined(p, typeof (DataMemberAttribute)));
现在我需要根据 DataMember
属性的 Order
属性对 propertyInfos
进行排序。因为有些可能会出现故障。
所以我尝试添加:
.OrderBy(p => ((DataFormat)Attribute.GetCustomAttribute(p, typeof (DataFormat))).Order);
但我收到“无法从使用情况推断”错误。
最佳答案
使用这个就可以了:
var orders = a1
.GetType()
.GetProperties()
.Where(x => Attribute.IsDefined(x, typeof(DataMemberAttribute)))
.Select(x => new { Att = x.GetCustomAttribute<DataMemberAttribute>(true), Prop = x })
.OrderBy(x => x.Att.Order);
Select()
投影一个由属性本身和属性组成的匿名对象,以便您可以按属性进行排序。
a1
是对象 ClassA
我修改了你的代码并使其正常工作:
var orders = a1
.GetType()
.GetProperties()
.Where(p => Attribute.IsDefined(p, typeof(DataMemberAttribute)))
.OrderBy(p => ((DataMemberAttribute)Attribute.GetCustomAttribute(p, typeof(DataMemberAttribute))).Order);
关于c# - 按其属性的属性值对 PropertyInfos 列表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33526422/