3.2 Dependencies of the Projects in the Solution 解决方案中项目间的依赖项
3.2 Dependencies of the Projects in the Solution 解决方案中项目间的依赖项
The diagram below shows the essential dependencies (project references) between the projects in the solution (IssueTracking.part is not shown to be simple)
解决方案中各项目之间的基本依赖关系(项目引用关系)(为了简化IssueTracking.部分没有显示):

The projects have been explained before. Now, we can explain the reasons of the dependencies;
前面我们已经解释过这些项目。现在,我们可以解释这些依赖项的原因。
- Domain.Shared is the project that all other projects directly or indirectly depend on. So, all the types in this project are available to all projects.
- Domain.Shared是所有其他项目直接或间接依赖的项目。所以,这个项目中的所有类型对所有项目都可用。
- Domain only depends on the
Domain.Sharedbecause it is already a (shared) part of the domain. For example, anIssueTypeenum in theDomain.Sharedcan be used by an Issue entity in the Domain project. - Domain只依赖于
Domain.Shared,因为它已经是Domain的一个(共享)部分。例如,Domain.Shared中的枚举类型IssueType可以被Domain项目中的Issue实体使用。 - Application.Contracts depends on the
Domain.Shared. In this way, you can reuse these types in the DTOs. For example, the sameIssueTypeenum in theDomain.Sharedcan be used by aCreateIssueDtoas a property. - Application.Contracts依赖于
Domain.Shared。通过这种方式,你可以在DTO中重用这些类型。例如,Domain.Shared中的同一个IssueType枚举可以被CreateIssueDto作为一个属性使用。 - Application depends on the
Application.Contractssince it implements the Application Service interfaces and uses the DTOs inside it. It also depends on theDomainsince the Application Services are implemented using the Domain Objects defined inside it. - Application依赖于
Application.Contracts,因为它实现了应用服务接口并使用其中的DTO。它也依赖于Domain,因为应用层服务是通过它里面定义的Domain对象实现的。 - EntityFrameworkCore depends on the
Domainsince it maps the Domain Objects (entities and value types) to database tables (as it is an ORM) and implements the repository interfaces defined in theDomain. - EntityFrameworkCore依赖于
Domain,因为它将领域对象(实体和值类型)映射到数据库表(因为它是一个ORM)并实现Domain中定义的存储库接口。 - HttpApi depends on the
Application.Contractssince the Controllers inside it inject and use the Application Service interfaces as explained before. - HttpApi依赖于
Application.Contracts,因为它里面的控制器注入并使用应用服务接口,前面已解释说明过。 - HttpApi.Client depends on the
Application.Contractssince it can consume the Application Services as explained before. - HttpApi.Client依赖于
Application.Contracts,因为它可以使用应用服务,前面已解释说明过。 - Web depends on the
HttpApisince it serves the HTTP APIs defined inside it. Also, in this way, it indirectly depends on theApplication.Contractsproject to consume the Application Services in the Pages/Components. - Web依赖于
HttpApi,因为它提供了在它里面定义的HTTP APIs。另外,通过这种方式,它间接地依赖于Application.Contracts项目运用于页面/组件中的应用服务。
Dashed Dependencies 隐含的依赖项
When you investigate the solution, you will see two more dependencies shown with the dashed lines in the figure above. Web project depends on the Application and EntityFrameworkCore projects which theoretically should not be like that but actually it is.
当你调查这个解决方案时,你会看到还有两个依赖关系,在上图中用虚线表示。Web项目依赖于Application项目和EntityFrameworkCore项目,理论上不应该是这样,但实际上是这样。
This is because the Web is the final project that runs and hosts the application and the application needs the implementations of the Application Services and the Repositories while running.
这是因为 Web项目是运行和托管应用程序的最终项目,应用程序在运行时需要应用服务和存储库的实现。
This design decision potentially allows you to use Entities and EF Core objects in the Presentation Layer which should be strictly avoided. However, we find the alternative designs over complicated. Here, two of the alternatives if you want to remove this dependency;
这个设计决定有可能让你在表现层中使用实体和EF核心对象,这应该是不允许的。然而,我们发现替代设计过于复杂。在这里,如果你想消除这种依赖关系,有两个备选方案:
- Convert Web project to a razor class library and create a new project, like Web.Host, that depends on the Web,Application and EntityFrameworkCore projects and hosts the application. You don't write any UI code here, but use only for hosting.
- 将
Web项目转换为Razor类库,并创建一个新的项目,如Web.Host,它依赖于Web,Application和EntityFrameworkCore项目并托管这个应用程序。你不在这里写任何UI代码,而只用于托管。 - Remove
ApplicationandEntityFrameworkCoredependencies from theWebproject and load their assemblies on application initialization. You can use ABP's Plug-In Modules system for that purpose. - 从
Web项目中移除Application和EntityFrameworkCore依赖,并在应用程序初始化时加载它们的程序集。你可以使用ABP的插件模块系统达到此目的。
3.2 Dependencies of the Projects in the Solution 解决方案中项目间的依赖项的更多相关文章
- Visual Studio Many Projects in One Solution VS中多工程开发
在用VS开发项目的时候,我们可以将不同的模块拆分开来,分别建立单独的Project来开发调试,整个放到一个Solution中就行了.这样做的好处是结构清晰,每个功能模块可以单独调试,而不用编译整个So ...
- Shortcut Collapse project or projects in the Solution Explorer Microsoft Visual Studio 2008
The standard windows keyboard shortcuts for expanding and collapsing treeviews are: Numeric Keypad * ...
- Gradle依赖项学习总结,dependencies、transitive、force、exclude的使用与依赖冲突解决
http://www.paincker.com/gradle-dependencies https://docs.gradle.org/current/userguide/dependency_man ...
- 3: 组件间的依赖管理 Managing Dependencies Between Components Using the Prism Library 5.0 for WPF(英汉对照版)
Applications based on the Prism Library are composite applications that potentially consist of many ...
- java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了
java组件不存在解决方案:右侧Maven Projects展开后左上角第一个刷新按钮 刷新后就会从新加载所有java的依赖项了 软件:idea 问题产生:其他同事进行开发,引入新java组件后提交 ...
- Maven问题总结:Eclipse中项目右键菜单中点击Maven->Update Projects时JDK被重置
Eclipse中在项目右键菜单点击->Maven->Update Projects时,JDK总是切回 1.5 如果没有在Maven中配置过JDK版本,只是在Eclipse中项目的Prope ...
- The POM for XXX is invalid, transitive dependencies (if any) will not be available解决方案
今天,某个开发的环境在编译的时候提示警告The POM for XXX is invalid, transitive dependencies (if any) will not be availab ...
- dependencies与devDependencies中应该放哪些依赖
网上一般的解释都是,开发环境用devDependencies,生产环境用dependencies,说的很简明,但是这里有个问题是,哪些包需要放到devDependencies中,哪些包需要放到depe ...
- SharePoint2016母版页的直接依赖项的数目限制超过10的限制解决方案Direct Dependencies Limit with Master page User Controls
前言 最近母版制作站点模板,根据站点模板新建后发现如下错误: 解决方案 1. 打开C:\inetpub\wwwroot\wss\VirtualDirectories\,如下图: 2. 打开web.co ...
随机推荐
- CountDownLatch能不能在多个线程上添加await?
在CountDownLatch类的使用过程中,发现了一个很奇怪的现象: CountDownLatch countDownLatch = new CountDownLatch(2); Runnable ...
- CodeReview杂谈
豆皮粉儿们,大家好,又见面啦,今天由字节跳动的"躬冯"带来一个 code review 的故事. 作者:躬冯 2020年元旦假期到来的时候,孙总攒了个局,又把当年一起创造过屎山的咱 ...
- noip模拟题7
目录 T1:匹配 T2:回家 思路 上代码: T3:寿司 基本思路: 上代码: T1:匹配 ##思路: 首先,这道题既可以用KMP,也可以用hash 先说KMP,首先要注意的一点是:KMP的n ...
- 学习Tomcat(一)之容器概览
Tomcat是Apache软件基金会的一个顶级项目,由Apache.Sun和其它一些公司及个人共同开发,是目前比较流行的Web服务器之一.Tomcat是一个开源的.小型的轻量级应用服务器,具有占用系统 ...
- Docker修改容器中的时间
Docker修改容器中的时间 前言 在公司开发时使用 Docker 创建数据库(SQL Server)的实例十分方便,还原数据库也只要设置好共享文件夹,在 SQL Server Management ...
- POJ1426——Find The Multiple
POJ1426--Find The Multiple Description Given a positive integer n, write a program to find out a non ...
- PTA——c++基本输入输出
1.使用提取符(<<)可以输出各种基本数据类型的变量的值,也可以输出指针值.(T) 2.预定义的插入符从键盘上接收数据是不带缓冲区的.(F) 3.使用操作符setw对数据进行格式输出时,需 ...
- 设置自启动nginx(适用于其他软件)(LinuxDeploy里的Ubuntu)
LinuxDeploy里的Ubuntu自启动nginx(适用于其他软件) 网上的教程是这样的,基本能用 1.编写脚本(这个文件及其内容安装Nginx后自动生成,没有的话内容自己Google) $ su ...
- IDEA 集成 Docker 插件实现一键远程部署 SpringBoot 应用,无需三方依赖,开源微服务全栈项目有来商城云环境的部署方式
一. 前言 最近有些童鞋对开源微服务商城项目 youlai-mall 如何部署到线上环境以及项目中 的Dockerfile 文件有疑问,所以写了这篇文章做个答疑以及演示完整的微服务项目发布到线上的流程 ...
- 使用OPCache提升PHP的性能
对于 PHP 这样的解释型语言来说,每次的运行都会将所有的代码进行一次加载解析,这样一方面的好处是代码随时都可以进行热更新修改,因为我们不需要编译.但是这也会带来一个问题,那就是无法承载过大的访问量. ...