asp.net-mvc – asp.net mvc强类型助手 – 你的渲染绑定对象应该与你的发布对象相同吗?

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – asp.net mvc强类型助手 – 你的渲染绑定对象应该与你的发布对象相同吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我看到asp.net mvc 2有强烈的输入帮助,并且最初看它的工作方式我认为也许我在asp.net mvc 1中做错了数据绑定以渲染视图并回发到控制器.

我经常有不同的对象来渲染视图并回发到控制器.这是错的?这似乎很自然,因为在渲染视图时,您经常会有一个包含下拉列表等的视图模型,但对于您的发布,您只需要回发所需的属性.

例如,在渲染的方式上,我的viewmodel可能看起来像这样

public class Personviewmodel
 {
      public int Age;
      public string FIrst;
      public JobCategory[] JobCategories;
      public Sport[] Sports;
      public int NumberOfChildren;

 }

在这种情况下,jobCategories和Sports将用于填充下拉框. NumberOfchildren将只是html放入,我不希望它可编辑.当我想发布我只想传回一个苗条的对象只有发布的属性,所以我有另一个对象

public class PersonUpdater
 {
      public int Age;
      public string FIrst;
      public int JobCategoryId;
 }

这些是我需要传回的唯一属性,所以我的控制器将如下所示:

public ActionResult Update(PersonUpdater personUpdater)
 {
      _repository.UpdateModel(personUpdater). 
 }

所以,鉴于上述情况,假设强类型辅助方法(如下所示)似乎对方法有用,但如果您引用不同的属性,则可能会导致回发到服务器的问题.

@L_502_0@

有什么想法吗?

解决方法

真正的问题是 – 当前接受的方法忽略了视图模型的 SRP – 编辑形式同时充当输入和输出.

人们还没有接受将视图模型划分为,正如我所说的,输入视图模型和输出视图模型(对于许多人来说 – 甚至创建视图模型层太多).因此 – Mvc2目前缺乏对此的支持(你不应该同时具有非输入和输出的强类型视图)主要是因为模糊和缺乏广泛接受的方法.

但我确实认为,在更深入地将视图模型分离为其中两个时,有一个好处(好吧……实际上是一种权衡).如果这个想法能够发展并最终被广泛接受,我也不会感到惊讶.

实际上 – 当前的方法甚至有一个名字 – Thunderdome principle.如果像杰里米·D·米勒这样的人说这是正确的,社区不会打扰,也不会搜索任何其他内容.

从实际角度来看 – 您可以通过提供正确的元数据来缓解一些问题(您可能需要查看fluent model metadata provider).

猜你在找的asp.Net相关文章