一个项目,有很多模块,把模块分出去,然后开发好后,再合并在一起,灵活度和组合度都非常的高。
延续Prism框架学习的项目,进行修改。
1.首先建立2个独立的模块项目。A和B操作一样,只说A即可。
2. 增加ViewA界面
3.在A项目上增加prism框架。
4.建立一个ModuleAfile类,类似作为和主程序交互的类,继承IModule,实现2个接口
using ModuleA.Views;
using Prism.Ioc;
using Prism.Modularity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ModuleA
{
public class ModuleAfile : IModule
{
public void OnInitialized(IContainerProvider containerProvider)
{
//初始化
}
public void RegisterTypes(IContainerRegistry containerRegistry)
{
//依赖注入,模块注册。和主程序继承PrismApplication类似。
containerRegistry.RegisterForNavigation<ViewA>();
}
}
}
5.回到主程序上,对A和B进行项目引用
6.在App.xaml.cs文件中,使用代码增加A和B模块
using ModuleA;
using ModuleB;
using Prism.DryIoc;
using Prism.Ioc;
using Prism.Modularity;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Threading.Tasks;
using System.Windows;
using WPFPrism.Views;
namespace WPFPrism
{
/// <summary>
/// Interaction logic for App.xaml
/// </summary>
public partial class App : PrismApplication
{
protected override Window CreateShell()
{
//通过容器去拿MainView,也是启动的地方
return Container.Resolve<MainView>();
}
protected override void RegisterTypes(IContainerRegistry containerRegistry)
{
//依赖注入的功能,增加依赖注入要实现的内容
//containerRegistry.RegisterForNavigation<ViewA>(); //containerRegistry.RegisterForNavigation<ViewA>("ViewA的具体名字")自定义,可以这样写;
//containerRegistry.RegisterForNavigation<ViewB>();
containerRegistry.RegisterForNavigation<ViewC>();//我们依然使用C模块,C模块是当前程序的。
}
protected override void ConfigureModuleCatalog(IModuleCatalog moduleCatalog)
{
//这里是走代码的
moduleCatalog.AddModule<ModuleAfile>();//加载A模块
moduleCatalog.AddModule<ModuleBfile>();//加载B模块
base.ConfigureModuleCatalog(moduleCatalog);
}
}
}
7.效果
拓展
使用配置文件的方式加载A和B模块
1.首先取消掉项目引用
2.在主程序exe文件夹下面,建立Modules文件夹
3.在App.xaml.cs文件中,使用配置增加A和B模块,这次的方法是CreateModuleCatalog
using Prism.DryIoc;
using Prism.Ioc;
using Prism.Modularity;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Threading.Tasks;
using System.Windows;
using WPFPrism.Views;
namespace WPFPrism
{
/// <summary>
/// Interaction logic for App.xaml
/// </summary>
public partial class App : PrismApplication
{
protected override Window CreateShell()
{
//通过容器去拿MainView,也是启动的地方
return Container.Resolve<MainView>();
}
protected override void RegisterTypes(IContainerRegistry containerRegistry)
{
//依赖注入的功能,增加依赖注入要实现的内容
//containerRegistry.RegisterForNavigation<ViewA>(); //containerRegistry.RegisterForNavigation<ViewA>("ViewA的具体名字")自定义,可以这样写;
//containerRegistry.RegisterForNavigation<ViewB>();
containerRegistry.RegisterForNavigation<ViewC>();//我们依然使用C模块,C模块是当前程序的。
}
protected override void ConfigureModuleCatalog(IModuleCatalog moduleCatalog)
{
//这里是走代码的
//moduleCatalog.AddModule<ModuleAfile>();//加载A模块
//moduleCatalog.AddModule<ModuleBfile>();//加载B模块
base.ConfigureModuleCatalog(moduleCatalog);
}
protected override IModuleCatalog CreateModuleCatalog()
{
//这里是走配置的
return new DirectoryModuleCatalog()
{
ModulePath = @"Modules"//这里是主程序exe同文件夹下面的Modules文件夹
};
//return base.CreateModuleCatalog();
}
}
}
4.主界面xaml代码
<Window x:Class="WPFPrism.Views.MainView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:prism="http://prismlibrary.com/"
prism:ViewModelLocator.AutoWireViewModel="True"
xmlns:local="clr-namespace:WPFPrism"
mc:Ignorable="d"
Title="MainView" Height="450" Width="800">
<!--自动关联AutoWireViewModel-->
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition />
</Grid.RowDefinitions>
<StackPanel Orientation="Horizontal" >
<Button Content="打开模块A" Margin="5" Command="{Binding OpenCommand}" CommandParameter="ViewA"/>
<Button Content="打开模块B" Margin="5" Command="{Binding OpenCommand}" CommandParameter="ViewB"/>
<Button Content="打开模块C" Margin="5" Command="{Binding OpenCommand}" CommandParameter="ViewC"/>
</StackPanel>
<ContentControl Grid.Row="1" prism:RegionManager.RegionName="Content" />
</Grid>
</Window>