public class MyController : Controller{ private MyClass _class; public MyController(MyClass class) { this._class = class; }}public class MyClass{ // stuff} 我的Ninject被连接到注入实现IController的类(Controller类这样做).但是
public class MyController : Controller { private MyClass _class; public MyController(MyClass class) { this._class = class; } } public class MyClass { // stuff }
我的Ninject被连接到注入实现IController的类(Controller类这样做).但是,我没有将MyClass绑定到任何东西,但是Ninject仍然将MyClass注入到MyController中.
我想我的问题是,为什么它会注入一些我没有绑定到任何东西的东西? Ninject会不会找到带有签名MyClass的类?我假设如果我的构造函数需要MyBaseClass并且我的程序集中有两个继承自MyBaseClass的类,则此行为会有所不同?
在Ninject V1中,ImplicitSelfBinding是一个顶级配置设置(默认为真正的IIRC).在V2中,您观察到的隐式自绑定行为更加深入(虽然有一些方法可以将其关闭 – 就像Ninject的大多数位一样,它非常精细且极小).在V2中,默认行为是,如果不存在其他绑定,则始终生成具体类型的自绑定.你通常只做一次Bind< Concrete>().ToSelf()是自定义绑定,例如,做一个.InSingletonScope().
有关在V2中关闭它的方法,请参见此answer by @Remo Gloor.
现在就在ImplicitSelfBinding中为源代码做一个grep – 虽然它比人们的兔子更容易阅读!
另外也不要忘记在Ninject.org上查看Ninject.Extensions.Conventions和测试,以便将I * X *的隐式Bind()输入到* X *
(正如Steven所提到的,如果你将MyClass类改为抽象的话,Ninject不会自我约束.)