我有一个名为TimeOfDay
的自定义结构,它在这样的视图模型中使用:
public class MyViewModel
{
public TimeOfDay TimeOfDay { get; set; }
}
我创建了一个名为TimeOfDayModelBinder
的自定义模型绑定器,并将其注册在Global.asax.cs中,如下所示:
ModelBinders.Binders.Add(typeof(TimeOfDay), new TimeOfDayModelBinder());
一切都很好。但是,如果我将我的视图模型更改为:
public class MyViewModel
{
public TimeOfDay? TimeOfDay { get; set; } // Now nullable!
}
我的自定义模型绑定器不再被调用。我知道该属性不再是TimeOfDay的类型,而是一个不同的Nullable。这是否意味着我应该在Global.asax.cs中添加我的自定义模型绑定器两次,如下所示:
ModelBinders.Binders.Add(typeof(TimeOfDay), new TimeOfDayModelBinder());
ModelBinders.Binders.Add(typeof(TimeOfDay?), new TimeOfDayModelBinder());
它有效,但我不喜欢它。这是否真的有必要将我的类型处理为可空,或者是否有我遗漏的东西?
答案 0 :(得分:8)
这不是你问题的真正答案,而是另一种解决方案。可能会有一个更好的......
在MVC3中,您可以创建一个IModelBinderProvider。实现将是这样的:
public class TimeOfDayModelBinderProvider : IModelBinderProvider
{
public IModelBinder GetBinder(Type modelType)
{
if(modelType == typeof(TimeOfDay) || modelType == typeof(TimeOfDay?))
{
return new TimeOfDayModelBinder();
}
return null;
}
}
您需要在DependencyResolver / IOC容器中注册 或 执行此操作(在Global.asax - app start中):
ModelBinderProviders.BinderProviders.Add(new TimeOfDayModelBinderProvider());
答案 1 :(得分:1)
Per @ LukeH的评论,似乎有必要。我想这也是有道理的,因为TimeOfDay
和Nullable<TimeOfDay>
在CLR中确实是两种不同的类型。所以我想我必须忍受它。 : - )