Merge pull request #10468 from TinyMaD/patch-1

Update Domain-Driven-Design-Implementation-Guide.md
pull/10469/head
liangshiwei 4 years ago committed by GitHub
commit 036e376c92
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1771,15 +1771,15 @@ public async Task ChangeTitleAsync(Issue issue, string title)
领域逻辑是系统的*核心领域规则*组成,而应用逻辑则满足特定的*用例*.
虽然定义很明确,但是实施起来缺并不容器.你可能无法确定哪些代码应该属于领域层,哪些代码应该属于应用层,本节会尝试解释差异.
虽然定义很明确,但是实施起来却并不容易.你可能无法确定哪些代码应该属于领域层,哪些代码应该属于应用层,本节会尝试解释差异.
### 多应用层
当你的系统很大时,DDD有助于**处理复杂问题**.尤其是,**单个领域**需要多个**应用程序运行**,那么**领域逻辑与应用逻辑分离**就变的非常重要.
假设你正构建一个具有多个应用程序的系统:
假设你正构建一个具有多个应用程序的系统:
* 一个**公开的应用网站**,使用ASP.NET Core MVC构建,展示商品给来访者.这样的网站不选哟身份验证即可查看商品.来访者只有执行了某些操作(例如,将商品添加到购物车)后,才需要登录网站.
* 一个**公开的应用网站**,使用ASP.NET Core MVC构建,展示商品给来访者.这样的网站不需要身份验证即可查看商品.来访者只有执行了某些操作(例如,将商品添加到购物车)后,才需要登录网站.
* 一个**后台管理系统**,UI使用Angular,通过REST API请求数据.内部员工使用这个系统来维护数据(例如,编辑商品说明).
* 一个**移动端应用程序**,它比公开的网站UI上更加简洁.它通过REST API或其它技术(例如,TCP sockets)请求数据.
@ -1787,7 +1787,7 @@ public async Task ChangeTitleAsync(Issue issue, string title)
每个应用程序都有不同的**需求**,不同的**用例**(应用服务方法),不同的DTO,不同的**验证**和**授权**规则等.
将所有这些逻辑都集中到一个应用层中,会使你的服务包含太多的`if`条件分支及**复杂的业务逻辑**,从而使你的代码难道开发,**维护**,测试,引发各种问题.
将所有这些逻辑都集中到一个应用层中,会使你的服务包含太多的`if`条件分支及**复杂的业务逻辑**,从而使你的代码开发,**维护**,测试,引发各种问题.
如果你在一个领域中有多个应用程序

Loading…
Cancel
Save