如果对NetCore中的依赖注入不了解决,建议先看看深入理解 ASP.NET Core 依赖注入
EntityModel对于原生依赖注入的封装类:Agebull.Common.Ioc.IocHelper
一 IocHelper类
- ServiceCollection属性
暴露了NetCore原生的IServiceCollection对象,象原生一样调用它 - AddTransient、AddScoped、AddSingleton
与原生的方法作用相同
您需要特别清楚NetCore依赖注入的三种生命同期:单例、范围、实例。
- Create 方法
简化依赖对象的构造。
二 如何使用
我想与其它框架的IServiceCollection对象保持一致
IocHelper.SetServiceCollection(services);
services为其它框架的依赖对象服务,如在Startup.cs中如下使用
public void ConfigureServices(IServiceCollection services)
{
IocHelper.SetServiceCollection(services);
}
我希望有一个全局唯一对象而不去管理对象如何构造与销毁
- 注册依赖
IocHelper.AddSingleton<AppManageDb, AppManageDb>();
注意,这两个泛型参数是一样的
- 使用时调用依赖构造
var db = IocHelper.Create<AppManageDb>();
认真观察你会发现,每次构造出的对象是同一个.
- 如果需求是范围唯一(如一次API调用过程),注册方法改为AddScoped即可。
我构造了一个基类,已有基础实现,但我希望将来派生类重载时可以轻松切换到派生类的实例
- 基类注册
IocHelper.AddSingleton<BaseObject, BaseObject>();
- 当派生类实现时
IocHelper.AddSingleton<BaseObject, SupperObject>();
后注册的会覆盖之前的注册。
我想控制构造的行为
IocHelper.AddSingleton<BaseObject, SupperObject>(() => mycode);
mycode写成你的构造行为即可