多态模型绑定这个问题问过在早期的MVC版本中。也有这篇博客文章一个解决问题的方法。我想知道MVC 3是否引入了可能有帮助的东西,或者是否还有其他选择。总之。情况就是这样。我有一个抽象的基模型和两个具体的子类。我有一个强类型视图,它将模型呈现为EditorForModel()..然后,我有自定义模板来呈现每个具体类型。这个问题是在事后发生的。如果我使POST操作方法以基类为参数,那么MVC就不能创建它的抽象版本(无论如何,我都不希望它创建实际的具体类型)。如果我创建了多个POST操作方法,这些方法仅随参数签名而变化,那么MVC会抱怨它不明确。据我所知,关于如何解决这个问题,我有几个选择。由于种种原因,我不喜欢它们中的任何一个,但我会在这里列出它们:创建自定义模型绑定,正如Darin在我链接的第一篇文章中所建议的那样。创建一个区分器属性,作为我链接到的第二个帖子。基于类型的发布到不同的动作方法???我不喜欢1,因为它基本上是隐藏的配置。其他一些从事代码开发的开发人员可能不知道这一点,并且浪费了大量的时间试图找出为什么在更改时事情会中断。我不喜欢2,因为它看起来有点烦人。但是,我倾向于这种方法。我不喜欢3,因为那意味着违反了干法。还有其他建议吗?编辑:我决定采用达林的方法,但做了一点小小的改变。我将其添加到抽象模型中:[HiddenInput(DisplayValue = false)]public string ConcreteModelType { get { return this.GetType().ToString(); }}然后在我的DisplayForModel()..你唯一要记住的是如果你不使用DisplayForModel()你得自己加进去。
3 回答
慕侠2389804
TA贡献1719条经验 获得超6个赞
[HttpPost]public ActionResult Index(MyModel model) {...}
[HttpPost]public ActionResult Index() {...}{ MyModel model; if (ViewData.SomeData == Something) { model = new MyDerivedModel(); } else { model = new MyOtherDerivedModel(); } TryUpdateModel(model); if (Model.IsValid) {...} return View(model);}
is
UpdateModel
TryUpdateModel
添加回答
举报
0/150
提交
取消