当前位置:首页 > 技术 > 正文内容

Prism框架入门与应用

访客 技术 2026年6月22日 17

1. 环境搭建

首先通过NuGet安装包`Prism.DryIoc`。

在App.xaml中引用Prism命名空间,将项目应用对象替换为`PrismApplication`,并移除`StartupUri`。

<prism:PrismApplication x:Class="MyApp.App"
         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
         xmlns:local="clr-namespace:MyApp"
         xmlns:prism="http://prismlibrary.com/">
</prism:PrismApplication>

修改App.xaml.cs文件,继承自`PrismApplication`并实现相关方法。

public partial class App : PrismApplication
{
    protected override Window CreateShell()
    {
        return Container.Resolve<MainWindow>();
    }

    protected override void RegisterTypes(IContainerRegistry registry)
    {
    }
}

为了实现动态绑定,需满足以下条件:

  • 视图应放置在Views文件夹下。
  • 视图模型应放置在ViewModels文件夹下。
  • 视图模型的命名规则应以视图名称开头,并以ViewModel结尾。
  • 设置自动绑定属性:`prism:ViewModelLocator.AutoWireViewModel="True"`。

2. 区域化功能

通过区域化功能,可以实现在同一窗口内切换不同的用户控件。

在主窗口添加一个`ContentControl`作为区域容器。

<Window x:Class="MyApp.Views.MainWindow">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="50"/>
            <RowDefinition/>
        </Grid.RowDefinitions>
        <StackPanel Orientation="Horizontal">
            <Button Command="{Binding LoadCommand}" CommandParameter="UserControlA" Content="加载模块A" Margin="5"/>
        </StackPanel>
        <ContentControl Grid.Row="1" prism:RegionManager.RegionName="MainRegion"/>
    </Grid>
</Window>

创建一个新的用户控件`UserControlA`。

<UserControl x:Class="MyApp.Views.UserControlA">
    <Grid>
        <TextBlock Text="这是模块A" FontSize="30"/>
    </Grid>
</UserControl>

在App.xaml.cs中注册该用户控件。

protected override void RegisterTypes(IContainerRegistry registry)
{
    registry.RegisterForNavigation<UserControlA>();
}

在视图模型中使用`RegionManager`进行导航。

public class MainWindowViewModel : BindableBase
{
    private readonly IRegionManager regionManager;

    public DelegateCommand<string> LoadCommand { get; private set; }

    public MainWindowViewModel(IRegionManager regionManager)
    {
        this.regionManager = regionManager;
        LoadCommand = new DelegateCommand<string>(LoadModule);
    }

    private void LoadModule(string moduleName)
    {
        regionManager.Regions["MainRegion"].RequestNavigate(moduleName);
    }
}

3. 模块化开发

模块化允许将不同功能划分为独立的模块。以下是实现步骤:

  1. 新建一个类库项目作为模块。
  2. 在模块项目中创建一个用户控件`ModuleView`。
  3. 实现`IModule`接口,完成模块注册。
public class ModuleProfile : IModule
{
    public void OnInitialized(IContainerProvider provider)
    {
    }

    public void RegisterTypes(IContainerRegistry registry)
    {
        registry.RegisterForNavigation<ModuleView, ModuleViewModel>();
    }
}

在主程序中管理模块:

protected override IModuleCatalog CreateModuleCatalog()
{
    return new DirectoryModuleCatalog() { ModulePath = @".\Modules" };
}

4. 导航功能

Prism支持页面间的导航,包括参数传递、日志记录等功能。

通过`NavigationParameters`传递参数。

private void NavigateTo(string target)
{
    NavigationParameters parameters = new NavigationParameters();
    parameters.Add("Message", "Hello from Main");
    regionManager.Regions["MainRegion"].RequestNavigate(target, parameters);
}

在目标视图模型中处理参数。

public class ModuleViewModel : BindableBase, INavigationAware
{
    public string Message { get; set; }

    public void OnNavigatedTo(NavigationContext context)
    {
        if (context.Parameters.ContainsKey("Message"))
            Message = context.Parameters.GetValue<string>("Message");
    }

    public bool IsNavigationTarget(NavigationContext context) => true;

    public void OnNavigatedFrom(NavigationContext context)
    {
    }
}

5. 对话框服务

通过`IDialogService`实现对话框功能。

public class MainWindowViewModel : BindableBase
{
    private readonly IDialogService dialogService;

    public MainWindowViewModel(IDialogService dialogService)
    {
        this.dialogService = dialogService;
    }

    public void ShowDialog()
    {
        DialogParameters parameters = new DialogParameters();
        parameters.Add("Title", "提示");

        dialogService.ShowDialog(nameof(DialogView), parameters, result =>
        {
            if (result.Result == ButtonResult.OK)
                string value = result.Parameters.GetValue<string>("ReturnValue");
        });
    }
}

定义对话框组件并实现`IDialogAware`接口。

public class DialogViewModel : BindableBase, IDialogAware
{
    public string Title { get; set; }
    public event Action<IDialogResult> RequestClose;

    public void OnDialogOpened(IDialogParameters parameters)
    {
        Title = parameters.GetValue<string>("Title");
    }

    public bool CanCloseDialog() => true;

    public void OnDialogClosed()
    {
        DialogParameters results = new DialogParameters();
        results.Add("ReturnValue", "关闭成功");
        RequestClose?.Invoke(new DialogResult(ButtonResult.OK, results));
    }
}

注册对话框组件。

protected override void RegisterTypes(IContainerRegistry registry)
{
    registry.RegisterDialog<DialogView, DialogViewModel>();
}

6. 发布订阅模式

通过事件聚合器实现跨模块通信。

public class EventMessage : PubSubEvent<string>
{
}

public class PublisherViewModel : BindableBase
{
    private readonly IEventAggregator aggregator;

    public PublisherViewModel(IEventAggregator aggregator)
    {
        this.aggregator = aggregator;
    }

    public void PublishMessage()
    {
        aggregator.GetEvent<EventMessage>().Publish("Test Message");
    }
}

public class SubscriberViewModel : BindableBase
{
    private readonly IEventAggregator aggregator;

    public SubscriberViewModel(IEventAggregator aggregator)
    {
        this.aggregator = aggregator;
        aggregator.GetEvent<EventMessage>().Subscribe(HandleMessage);
    }

    private void HandleMessage(string message)
    {
        MessageBox.Show($"Received: {message}");
    }
}
标签: PrismDryIocWPF

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。