gpt4 book ai didi

mvvm - 领域模型对 View 模型的依赖有多糟糕?

转载 作者:行者123 更新时间:2023-12-03 10:12:54 25 4
gpt4 key购买 nike

我继承了一些仍在进行中的代码。我认为它有一个明显的架构问题:

它有一个包含所有域实体(域层)的项目和一个包含所有应用程序服务(应用层)的项目。应用层依赖于领域层。到目前为止,一切都很好。然后是第三个项目,其中包含应用层的所有 View 模型。我将其称为 View 模型层。很好。

问题是,我已经意识到域层对 View 模型层具有主动依赖性。它是什么,他们在这里为每个实体放置了一堆元数据,主要是各种字符串字段的最大长度,并且域实体和 View 模型都引用这些常量值。

我很确定让您的领域模型以这种方式依赖于 View 模型是非常糟糕的。我发现这一点是因为我想将域模型用于 View 模型中的某些内容,但发现我不能这样做,因为它会导致循环引用。

所以我的问题是:这个架构有多糟糕?或者我真的错了,这根本不是问题。我实际上找不到答案,可能是因为它被认为太明显了。此外,人们通常如何处理域实体和 View 模型共有的字段元数据(如最大长度)?把它写在多个地方似乎很浪费。

我将 c# MVC 与 Angular 客户端一起使用是为了它的值(value)。

提前致谢。

最佳答案

Clean Architecture push us to separate stable business rules(higher-level abstractions) from volatile technical details(lower-level details), defining clear boundaries. The main buildingblock is the Dependency Rule: source code dependencies must point onlyinward, toward higher-level modules. Higher level modules shouldn'tdepend on the lower level modules.

您的域模型不应依赖于 View 模型。它打破了 Robert C. Martin 提出的最重要的清洁架构规则。

how bad is this architecture?

它和它产生的问题一样糟糕。您已经指出的第一个 - 您不能在 View Models 模块中引用 Domain Models 模块。领域模型已经足够复杂了,因为它解决了领域问题。您不应通过引用细节(如 View 模型)来增加额外的复杂性。我能想到的另一个问题是,你拥有的依赖越多,你的领域模型就越难测试。

Also, what do people normally do for field meta-data (like max length)which is common to both the domain entities and the view models? Seemsa waste to write it out in more than one place.

验证规则可以有不同的来源,例如:

  • 技术数据库限制
  • 业务规则
  • GUI 友好
  • 其他?

您应该考虑您拥有的每个验证规则,并确定它的来源。如果验证规则在业务规则方面有意义,我会把它放在域模型中。也许有些验证规则不应该出现在您的域模型中?希望对您有所帮助:)。

另请参阅这篇文章:Data validation

关于mvvm - 领域模型对 View 模型的依赖有多糟糕?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57784424/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com