- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我听到有人说你不应该为你的依赖注入(inject)使用服务定位器。那么如何在不依赖服务定位器的情况下注入(inject)依赖项呢?我想尝试 IoC 容器,但不想陷入反模式。
您是否应该设置所有内容,以便所有类始终具有到最深层类的依赖链? (如果我/那完全有意义的话)
让您的所有代码都依赖于所选 IoC 容器是不对的,对吗?
那么你在哪里“使用”你的容器(用于 rexolving)?你如何让它解决所有问题,就像你的代码一样深入?它是通过在每一层直到前层使用接口(interface)以正确的方式设计一切的一部分吗?
还是我漏掉了一点?
让我提醒您,我只是不想陷入反模式,需要一些提示/提醒。
最佳答案
Should you just set everything up so there is one place where all classes always have a dependency chain to the deepest classes? (if I/that makes sense at all)
是的,这称为应用程序的组合根,您可以在其中配置 IoC 容器并解析根类型。
It isn't right to have all your code littered with dependencies on the IoC container of choice, is it?
正确,最好不要围绕您的类型传递对 IoC 容器的引用,因为这会降低它们的可重用性,并且通常会将类型与 IoC 容器的概念相结合。
So where do you "use" your the container (for rexolving)? And how do you get it to resolve everything, as deep as your code goes? Is it a part of designing everything the right way by using interfaces through every layer up till the front layer?
您可以在组合根目录以及代码中需要通过容器实例化类型(即从工厂类型)的任何地方使用容器(通常用于依赖链支持)。
许多 IoC 容器可以为您生成这些工厂类型,因此您只需要通过,例如IMyFactory
作为依赖项,或者在某些 IoC 容器的情况下,一个 Func<IMyService>
.这意味着您不需要创建依赖于 IoC 容器的工厂类型。
在使用接口(interface)方面,依赖倒置原则规定你应该依赖抽象,而不是具体化,所以如果你想采用依赖注入(inject),你需要考虑到这个概念来分解你的代码。
关于dependency-injection - 如何使用依赖注入(inject)而不是服务定位器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5460564/
我正在尝试测试依赖于其他服务 authService 的服务 documentViewer angular .module('someModule') .service('docu
如果我的网站上线(不要认为它会,目前它只是一个学习练习)。 我一直在使用 mysql_real_escape_string();来自 POST、SERVER 和 GET 的数据。另外,我一直在使用 i
我有以下代码,它容易受到 SQL 注入(inject)的攻击(我认为?): $IDquery = mysqli_query($connection, "SELECT `ID` FROM users W
我一直在自学如何创建扩展,以期将它们用于 CSS 注入(inject)(以及最终以 CSS 为载体的 SVG 注入(inject),但那是以后的问题)。 这是我当前的代码: list .json {
这个简单的代码应该通过 Java Spring 实现一个简单的工厂。然而结果是空指针,因为 Human 对象没有被注入(inject)对象(所以它保持空)。 我做错了什么? 谢谢 配置 @Config
我正在编写一个 ASP.NET MVC4 应用程序,它最终会动态构建一个 SQL SELECT 语句,以便稍后存储和执行。动态 SQL 的结构由用户配置以用户友好的方式确定,具有标准复选框、下拉列表和
首先让我说我是我为确保 SQL 注入(inject)攻击失败而采取的措施的知己。所有 SQL 查询值都是通过事件记录准备语句完成的,所有运算符(如果不是硬编码)都是通过数字白名单系统完成的。这意味着如
这是 SQL 映射声称可注入(inject)的负载: user=-5305' UNION ALL SELECT NULL,CONCAT(0x716b6b7071,0x4f5577454f76734
我正在使用 Kotlin 和 Android 架构组件(ViewModel、LiveData)构建一个新的 Android 应用程序的架构,并且我还使用 Koin 作为我的依赖注入(inject)提供
假设 RequestScope 处于 Activity 状态(使用 cdi-unit 的 @InRequestScope) 给定 package at.joma.stackoverflow.cdi;
我有一个搜索表单,可以在不同的提供商中搜索。 我从拥有一个基本 Controller 开始 public SearchController : Controller { protected r
SQLite 注入 如果您的站点允许用户通过网页输入,并将输入内容插入到 SQLite 数据库中,这个时候您就面临着一个被称为 SQL 注入的安全问题。本章节将向您讲解如何防止这种情况的发生,确保脚
我可以从什么 dll 中获得 Intercept 的扩展?我从 http://github.com/danielmarbach/ninject.extensions.interception 添加了
使用 NInject 解析具有多个构造函数的类似乎不起作用。 public class Class1 : IClass { public Class1(int param) {...} public
我有一个 MetaManager 类: @Injectable() export class MetaManager{ constructor(private handlers:Handler
我是 Angular 的新手,我不太清楚依赖注入(inject)是如何工作的。我的问题是我有依赖于服务 B 的服务 A,但是当我将服务 A 注入(inject)我的测试服务 B 时,服务 B 变得未定
我正在为我的项目使用 android 应用程序启动、刀柄和空间。我在尝试排队工作时遇到错误: com.test E/WM-WorkerFactory: Could not instantiate co
我不确定这是什么糖语法,但让我向您展示问题所在。 def factors num (1..num).select {|n| num % n == 0} end def mutual_factors
简单的问题,我已经看过这个了:Managing imports in Scalaz7 ,但我不知道如何最小化注入(inject) right和 left方法到我的对象中以构造 \/ 的实例. 我确实尝
在我的 Aurelia SPA 中,我有一些我想在不同模块中使用的功能。它依赖于调用时给出的参数和单例的参数。有没有办法创建一个导出函数,我可以将我的 Auth 单例注入(inject)其中,而不必在
我是一名优秀的程序员,十分优秀!