Prism框架的Module(模块化)编程
Prism框架用的是新版本的,Prism7.1。关于其中的变动,感兴趣的参考https://www.cnblogs.com/hicolin/p/8694892.html
如何告诉Shell(我们的宿主程序)去Load哪些Module,Prism框架用的是模块目录ModuleCatalog,ModuleCatalog包含了可以被APP使用的模块信息。
方式一:通过配置文件(App.config)创建模块目录(ModuleCatalog)
1、新建Prism Blank App(WPF) 项目:BlankApp7
BlankApp7处鼠标右键——添加——新建项——应用程序配置文件,App.config
2、新建Prism Module(WPF)项目:ModuleA
3、ModuleA中有个ModuleAModule.cs文件,实现ViewA与主窗体的ContentRegion的关联(四种方式的ModuleAModule.cs内容都一样)
using ModuleA.Views; using Prism.Ioc; using Prism.Modularity; using Prism.Regions; namespace ModuleA { public class ModuleAModule : IModule { public void OnInitialized(IContainerProvider containerProvider) { var regionManager = containerProvider.Resolve<IRegionManager>(); regionManager.RegisterViewWithRegion("ContentRegion", typeof(ViewA)); //viewA与ContentRegion进行关联 } public void RegisterTypes(IContainerRegistry containerRegistry) { } } }
App.xaml.cs目录创建于配置文件
using BlankApp7.Views; using Prism.Ioc; using Prism.Modularity; using System.Windows; namespace BlankApp7 { public partial class App { protected override Window CreateShell() { return Container.Resolve<MainWindow>(); } protected override void RegisterTypes(IContainerRegistry containerRegistry) { } protected override IModuleCatalog CreateModuleCatalog() { return new ConfigurationModuleCatalog(); //目录创建于配置文件 } } }
配置文件App.config,可知有一个名为ModuleAModule的Module,集合于ModuleA.dll中,startupLoaded是否在启动时就加载(显示)。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <configSections> <section name="modules" type="Prism.Modularity.ModulesConfigurationSection, Prism.Wpf" /> </configSections> <modules> <module assemblyFile="ModuleA.dll" moduleType="ModuleA.ModuleAModule, ModuleA" moduleName="ModuleAModule" startupLoaded="True" /> </modules> </configuration>
4、由于BlankApp7要加载ModuleA,所以要引用ModuleA生成的dll。
ModuleA处鼠标右键——生成,ModuleA的bin文件夹中就会出现ModuleA.dll
BlankApp7处鼠标右键——添加——引用,浏览,找到ModuleA.dll(不建议复制粘贴dll到BlankApp7的bin目录,因为如果重新生成ModuleA.dll,那么新的dll不会出现在BlankApp7的bin目录,依旧是拷贝的旧dll)
运行结果如图
方式二:Code方法,调用AddModule()
仿照方式一创建项目BlankApp8、ModuleA,只需要更改ModuleAModule.cs、App.xaml.cs。其他文件默认不动。
ModuleAModule.cs,内容与方式一一样
App.xaml.cs
using BlankApp8.Views; using Prism.Ioc; using Prism.Modularity; using System.Windows; namespace BlankApp8 { public partial class App { protected override Window CreateShell() { return Container.Resolve<MainWindow>(); } protected override void RegisterTypes(IContainerRegistry containerRegistry) { } protected override void ConfigureModuleCatalog(IModuleCatalog moduleCatalog) //配置模块目录 { moduleCatalog.AddModule<ModuleA.ModuleAModule>(); //使用AddModule方法 } } }
运行时,依然按照方式一的第4步骤生成并引用dll。
方式三:指定dll所在目录的方式,因此就不用按照方式一的第4步骤生成并引用dll了。
与方式二一样,只需要更改两个文件ModuleAModule.cs、App.xaml.cs。ModuleAModule.cs内容与方式一一样。
App.xaml.cs指定要加载的dll的目录
using BlankApp8.Views; using Prism.Ioc; using Prism.Modularity; using System.Windows; namespace BlankApp8 { public partial class App { protected override Window CreateShell() { return Container.Resolve<MainWindow>(); } protected override void RegisterTypes(IContainerRegistry containerRegistry) { } protected override IModuleCatalog CreateModuleCatalog() { //return new DirectoryModuleCatalog() { ModulePath = @"./" }; //当前目录,即BlankApp8\BlankApp8\bin\Debug。需拷贝ModuleA.dll到当前目录中 return new DirectoryModuleCatalog() { ModulePath = @"C:\Users\jv\source\repos\BlankApp8\ModuleA\bin\Debug" };//不拷贝ModuleA.dll,使用绝对目录 } } }
方式四:加载模块的方式,与方式一同样可以实现内容的显示与否。
只需要更改两个文件ModuleAModule.cs、App.xaml.cs。ModuleAModule.cs内容与方式一一样。
App.xaml.cs
using BlankApp8.Views; using ModuleA; //引入ModuleA using Prism.Ioc; using Prism.Modularity; using System.Windows; namespace BlankApp8 { public partial class App { protected override Window CreateShell() { return Container.Resolve<MainWindow>(); } protected override void RegisterTypes(IContainerRegistry containerRegistry) { } protected override void ConfigureModuleCatalog(IModuleCatalog moduleCatalog) { var moduleAType = typeof(ModuleAModule); moduleCatalog.AddModule(new ModuleInfo() { ModuleName = moduleAType.Name, ModuleType = moduleAType.AssemblyQualifiedName, InitializationMode = InitializationMode.WhenAvailable //显示View内容 //InitializationMode = InitializationMode.OnDemand //不显示View内容 }); } } }
运行时,依然按照方式一的第4步骤生成并引用dll。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2016-09-08 平均灰度、平均对比度、平滑度、三阶矩、一致性、熵