类型可为空时,不调用自定义模型绑定器

时间:2011-04-03 23:21:00

标签: c# asp.net-mvc-3 custom-model-binder

我有一个名为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());

它有效,但我不喜欢它。这是否真的有必要将我的类型处理为可空,或者是否有我遗漏的东西?

2 个答案:

答案 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的评论,似乎有必要。我想这也是有道理的,因为TimeOfDayNullable<TimeOfDay>在CLR中确实是两种不同的类型。所以我想我必须忍受它。 : - )