EntityModel 系列之 依赖注入

如果对NetCore中的依赖注入不了解决,建议先看看深入理解 ASP.NET Core 依赖注入

EntityModel对于原生依赖注入的封装类:Agebull.Common.Ioc.IocHelper

一 IocHelper类

  1. ServiceCollection属性
    暴露了NetCore原生的IServiceCollection对象,象原生一样调用它
  2. AddTransient、AddScoped、AddSingleton
    与原生的方法作用相同

您需要特别清楚NetCore依赖注入的三种生命同期:单例、范围、实例。

  1. Create 方法
    简化依赖对象的构造。

二 如何使用

我想与其它框架的IServiceCollection对象保持一致
IocHelper.SetServiceCollection(services);

services为其它框架的依赖对象服务,如在Startup.cs中如下使用

 public void ConfigureServices(IServiceCollection services)
 {
     IocHelper.SetServiceCollection(services);
 }
我希望有一个全局唯一对象而不去管理对象如何构造与销毁
  1. 注册依赖
IocHelper.AddSingleton<AppManageDb, AppManageDb>();

注意,这两个泛型参数是一样的

  1. 使用时调用依赖构造
var db = IocHelper.Create<AppManageDb>();

认真观察你会发现,每次构造出的对象是同一个.

  1. 如果需求是范围唯一(如一次API调用过程),注册方法改为AddScoped即可。
我构造了一个基类,已有基础实现,但我希望将来派生类重载时可以轻松切换到派生类的实例
  1. 基类注册
IocHelper.AddSingleton<BaseObject, BaseObject>();
  1. 当派生类实现时
IocHelper.AddSingleton<BaseObject, SupperObject>();

后注册的会覆盖之前的注册。

我想控制构造的行为
IocHelper.AddSingleton<BaseObject, SupperObject>(() => mycode);

mycode写成你的构造行为即可

猜你喜欢

转载自blog.csdn.net/longhutian/article/details/88228090