zoukankan      html  css  js  c++  java
  • 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 = @"./" }; //当前目录,即BlankApp8BlankApp8inDebug。需拷贝ModuleA.dll到当前目录中
                return new DirectoryModuleCatalog() { ModulePath = @"C:Usersjvsource
    eposBlankApp8ModuleAinDebug" };//不拷贝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。

  • 相关阅读:
    flask 非要将视图和app放在一个空间
    spring mvc 实用的思想
    不能在windows上使用但值得关注的项目
    AI 医疗
    我也是混乱了同步盘和网盘
    常用free文献数据库
    机器学习中如何处理不平衡数据?
    自己制作的学习笔记视屏,还有记录的代码。
    函数的指针(一)写一个能对任意数组排序的冒泡排序
    自己写一个swap函数交换任意两个相同类型元素的值 对空指针的使用 字节大小的判断(二)了解原理
  • 原文地址:https://www.cnblogs.com/xixixing/p/11488218.html
Copyright © 2011-2022 走看看