我有一个基于模型的DescriptionFor
助手,如下所示:
public static HtmlString DescriptionFor<TModel, TProperty>(
this HtmlHelper<TModel> htmlHelper,
Expression<Func<TModel, TProperty>> expression) where TModel : class
{
var metaData = ModelMetadata.FromLambdaExpression(expression, htmlHelper.ViewData);
return new HtmlString(metaData.Description.ToStringOrEmpty());
}
这会关闭DataAnnotations.DisplayAttribute
(特别是Description
参数),并且可以顺利运行。
我现在有一个案例,我的模型有IEnumerable<foo>
我正在循环播放,foo
为每个枚举成员都有DisplayAttribute
个枚举。大多数(但不是全部)DisplayAttribute
属性提供了Description
属性,我想在我的循环中公开它,如下所示:
@foreach(var fooObject in Model.foos){
@Html.Description(fooObject, x=>x.fooEnumVal)
}
...这将显示每个foo
对象的枚举值描述。
我很快发现它与模型助手不太相似。有人能指出我正确的方向吗?
答案 0 :(得分:0)
您可以使用for循环代替foreach并使用助手获取说明
@for(int i =0; i < Model.foos.Count(); i++){
@Html.Description(x => x.foos[i].fooEnumVal)
}
此外,您可以创建新的辅助方法,为指定的模型创建新的viewdatadictionary并获取属性的元数据(我没有检查它,但它应该工作:))
public static HtmlString DescriptionFor<TModel, TProperty>(this HtmlHelper<TModel> htmlHelper, TModel model, Expression<Func<TModel, TProperty>> expression)
where TModel : class
{
var metaData = ModelMetadata.FromLambdaExpression(expression, new ViewDataDictionary<TModel>(model));
return new HtmlString(metaData.Description.ToStringOrEmpty());
}
希望有所帮助
答案 1 :(得分:0)
我最终做了这样的事情:
public static HtmlString DescriptionFor(this Enum theEnum)
{
var theEnumType = theEnum.GetType();
//the enum must inherit from Enum, but not actually *be* Enum.
if (!(theEnum is Enum) || theEnumType.Equals(typeof(Enum))) throw new ArgumentException("Not a valid Enumeration.");
var fi = theEnumType.GetField(theEnum.ToString());
var displayAttribute = ((DisplayAttribute[])fi.GetCustomAttributes(typeof(DisplayAttribute), false))
.FirstOrDefault();
if (displayAttribute == null) return new HtmlString(theEnum.ToString());
return new HtmlString(displayAttribute.Description ?? theEnum.ToString());
}
我确信这不是最好的方式,但我能够有效地写在我的观点中:
@fooObject.enumVal.DescriptionFor()
按照我的意愿进行。