XiaoYou.Ump提供了构建模块的基础结构,并将它们组合在一起以创建应用程序。模块可以依赖于另一个模块。通常,组件被视为模块。如果创建具有多个程序集的应用程序,建议您为每个程序集创建一个模块定义。
模块系统当前专注于服务端而不是客户端。
名词解释 : Assembly
程序集:Assembly 是一个用来包含程序的名称,版本号,自我描述,文件关联关系和文件位置等信息的一个集合。最简单的理解就是:一个你自己写的类库生成的 dll 就可以看做是一个程序集,这个程序集可以包括很多类,类又包括很多方法等。
一个派生自 UmpModule 的类就是模块的定义。假设我们正在开发一个可以在不同应用程序中使用的Blog模块。最简单的模块定义如下所示:
public class MyBlogModule : UmpModule //定义
{
public override void Initialize() //初始化
{
IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
//这行代码的写法基本上是不变的。它的作用是把当前程序集的特定类或接口注册到依赖注入容器中。
}
}
如果需要,模块定义类负责通过依赖注入来注册它的类 (它可以按常规方式完成,如上所示)。它还可以配置应用程序和其他模块,为应用程序添加新功能,等等......
Ump在应用程序启动和关闭时调用某些特定的模块方法。您可以覆盖这些方法以执行某些特定任务。
Ump 框架通过依赖关系的顺序来调用这些方法,假如:模块 A 依赖于模块 B,那么模块 B 要在模块 A 之前初始化,模块启动的方法顺序如下:
下面是具体方法的说明:
当应用程序启动时,首先调用此方法。它是在初始化之前配置框架和其他模块的首选方法。
在依赖注入注册之前,你可以在这个方法中指定你需要注入的自定义启动类。例如:加入你创建了某个符合约定的注册类,你应该使用 IocManager.AddConventionalRegisterer 方法在这里注册它。
初始化:在这个方法中一般是来进行依赖注入的注册,一般我们通过 IocManager.RegisterAssemblyByConvention 这个方法来实现。如果你想实现自定义的依赖注入,那么请参考依赖注入的相关文档。
初始化后:最后一个方法,这个方法用来解析依赖关系。
关闭:当应用关闭以后,这个方法被调用。
Ump 框架会自动解析模块之间的依赖关系,但是我们还是建议使用DependsOn属性显式声明依赖项,如下所示:
[DependsOn(typeof(MyBlogCoreModule))]//通过注解来定义依赖关系
public class MyBlogApplicationModule : AbpModule
{
public override void Initialize()
{
IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
}
}
例如上面的代码,我们就声明了 MyBlogApplicationModule 和 MyBlogCoreModule 的依赖关系,MyBlogApplicationModule 这个应用模块依赖于 MyBlogCoreModule 核心模块,并且,MyBlogCoreModule 核心模块会在 MyBlogApplicationModule 模块之前进行初始化。
Ump 可以从 startup module 递归的解析依赖关系,并按需初始化它们。最后初始化的模块是启动模块(startup module)。
我们自己定义的模块中可能有方法被其他依赖于当前模块的模块调用,下面的例子,假设模块 2 依赖于模块 1,并且想在预初始化的时候调用模块 1 的方法。这样,就把模块 1 注入到了模块 2,因此,模块 2 就能调用模块 1 的方法了。
public class MyModule1 : AbpModule
{
public override void Initialize() //初始化模块
{
IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());//这里,进行依赖注入的注册。
}
public void MyModuleMethod1()
{
//这里写自定义的方法。
}
}
[DependsOn(typeof(MyModule1))]
public class MyModule2 : AbpModule
{
private readonly MyModule1 _myModule1;
public MyModule2(MyModule1 myModule1)
{
_myModule1 = myModule1;
}
public override void PreInitialize()
{
_myModule1.MyModuleMethod1(); //调用MyModuleMethod1的方法。
}
public override void Initialize()
{
IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
}
}
虽然自定义模块可以被用来配置模块,但是,作者建议使用启动配置来定义和配置模块。
所有的模块类都被自动的注册为单例模式。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。