ASP.NET MVC:将ViewModel嵌套在彼此之内,反模式还是没有?

Jus*_*ray 5 model-view-controller viewmodel

我有一个项目,其中ViewModels彼此嵌套,这样它们本质上是域层次结构的字符串类型复制.例如,如果我们的域具有以下关系:

组织有1到多个环境

环境有1到多台机器

然后会有一个OrganizationViewModel,其中包含一个或多个EnvironmentViewModel,而EnvironmentViewModel本身就有一个到多个MachineViewModel.然后,在整个应用程序中重用此样式的层次结构,其中包含此类型的大约五个ViewModel之一.(例如,EnvironmentViewModel用于多个页面,MachineViewModel也适用于其中许多页面,具体取决于正在查看的层次结构的级别...我为了讨论的目的简化了这个,但是层次结构比上面的3更大).

现在,尽管我想从上面下来并谴责这种做法,但我还是找不到有关此问题的更多信息.有人能指出我有关既定做法的更多细节吗?轶事分享?

(我自己的偏见是这些ViewModel不应该以这种方式嵌套在彼此之内,并且ViewModel实际上应该对应于Views,而不是域对象.我发现它对于一些可维护性问题非常混乱.但我想要知道别人的想法或经历过.)

我已经附上这个问题以供参考,但它描述了在视图模型中嵌套域对象,而不是在彼此之间嵌入视图模型.

And*_*ock 6

视图模型应尽可能平坦(尽管用于逻辑分组多个相关属性的嵌套不可变对象可用于整理目的).

不要把它想象为"视图模型应该对应于视图",反过来想一想:"视图是视图模型数据的html表示".

ViewModel 是一个可怕的术语,因为它不是一个观点,它不是一个模型,它是一种资源的代表.

如果我做:

`GET /User/1`
Run Code Online (Sandbox Code Playgroud)

我期待回来一些代表用户1的数据.如果那是HTML格式,因为我发送了

`Accept: text/html`
Run Code Online (Sandbox Code Playgroud)

那就这样吧.考虑一下您的viewmodel看起来像XML或JSON.

在创建依赖关系链时尝试避免嵌套视图模型,只需复制属性,而不是真的违反DRY

  • 我认为"考虑你的viewmodel看起来像xml或json"这一点可能是最重要的一点,在这里.我经常使用该透视图来帮助我理解视图模型应该是什么样的,并帮助我理解什么数据是"viewmodel"数据与"视图的HTML呈现中的数据".有助于保持清洁并将它们分开 (2认同)