Caliburn.Micro框架学习笔记——多页面处理案例

2024-06-02 06:44

本文主要是介绍Caliburn.Micro框架学习笔记——多页面处理案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在聊这个之前,我们先来看一个静态类

在 Caliburn.Micro 中,ViewLocator 是一个用于查找和关联视图与视图模型的静态类。默认情况下,它根据约定(命名约定或其他规则)自动找到与视图模型相对应的视图。然而,有时我们需要自定义这一过程,以便在某些特殊情况下控制视图的定位和创建。

通过设置 ViewLocator.LocateForModelType,你可以提供一个自定义的逻辑来查找和创建视图。

ce02adecaaf1447599b48e8c855c9d13.png

这里就是传入一个委托,这个委托是我们自定义的一个逻辑,它用于将视图模型类型映射到对应的视图。通过设置这个委托,你可以覆盖默认的视图定位逻辑。

基本结构——

public static Func<Type, DependencyObject, object, UIElement> LocateForModelType;

  • Type:视图模型的类型。
  • DependencyObject:上下文对象,通常是当前的视图。
  • object:上下文数据,通常是视图模型。
  • UIElement:返回找到的视图

 使用实例——

View层

<Window x:Class="YourNamespace.YourSpecialView"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="YourSpecialView" Height="200" Width="300"><Grid><TextBlock Text="This is a special view!" HorizontalAlignment="Center" VerticalAlignment="Center"/></Grid>
</Window>

VM层

namespace YourNamespace
{public class YourSpecialViewModel : Screen{// ViewModel logic for the special view}
}

在startup中创建他们的映射

 protected override void Configure(){// 设置自定义的视图定位器ViewLocator.LocateForModelType = new Func<Type, DependencyObject, object, UIElement>(OnLocateForModelType);}private UIElement OnLocateForModelType(Type modelType, DependencyObject displayLocation, object context){// 自定义逻辑,例如根据某些条件选择视图if (modelType == typeof(YourSpecialViewModel)){return new YourSpecialView();}else{// 使用默认逻辑return ViewLocator.LocateForModelTypeDefault(modelType, displayLocation, context);}}

以上清楚之后,我们继续。

假设我们有多个窗口(UserControl),且要让他们显示在一个Tab中。那我们可以这么做。

首先先创建一个IChileViewModel这个来统一要显示的那几个usercontrol的VM,之后通过名称来进行判别打开的要是哪个。

   public interface IChildViewModel{}

然后在一开始的时候,我们讲过ViewLocator这个内容,这个很重要,我们可以自定义一个匹配逻辑如下——

private UIElement OnLocateForModelType(Type type, DependencyObject d, object obj)
{string name = type.FullName;name = name.Replace(".ViewModels.", ".Views.");if (name.EndsWith("Model"))name = name.Substring(0, name.Length - 5);var t = Assembly.GetExecutingAssembly().GetType(name);//这里可以顺便注入viewreturn (UIElement)Activator.CreateInstance(t);
}

于是在startup这个类中,初始类配置代码为——》

  internal class Startup : BootstrapperBase{private SimpleContainer _container;public Startup(){this.Initialize();ViewLocator.LocateForModelType =new Func<Type, DependencyObject, object, UIElement>(OnLocateForModelType);}private UIElement OnLocateForModelType(Type type, DependencyObject d, object obj){string name = type.FullName;name = name.Replace(".ViewModels.", ".Views.");if (name.EndsWith("Model"))name = name.Substring(0, name.Length - 5);var t = Assembly.GetExecutingAssembly().GetType(name);// 这里可以加入View的依赖注入功能//----------------------------------return (UIElement)Activator.CreateInstance(t);}protected override async void OnStartup(object sender, StartupEventArgs e){await DisplayRootViewForAsync<MainViewModel>();}protected override void Configure(){_container = new SimpleContainer();this._container.Instance(this._container);this._container.Singleton<IEventAggregator, EventAggregator>().Singleton<IWindowManager, WindowManager>();this._container.PerRequest<MainViewModel>().Singleton<IChildViewModel, AViewModel>("A").Singleton<IChildViewModel, BViewModel>("B").Singleton<IChildViewModel, CViewModel>("C");}protected override object GetInstance(Type service, string key){return this._container.GetInstance(service, key);}}

 这里注入时,通过特定字母进行之后的窗体索引。

于是在Mainview中可以创建如下,用来做测试

cdfd12d72d3640a79ddb77a47d61d665.png

VM中的逻辑为

  // 使用TabControl -》必须 Conductor<object>.Collectionpublic class MainViewModel : Conductor<object>.Collection.OneActive{public async void ShowPage(string name){var vm = IoC.Get<IChildViewModel>(name);await this.ActivateItemAsync(vm);}}

这里需要注意的是,要显示的那几个内容,都需要继承IChlidViewModel和Screen。然后通过MainView做统一管理,所以其需要继承Conductor<object>。

当我按下其中一个按钮,要将其显示在tabcontrl中时,此时会跳转到之前的ViewLocator中去进行映射。而映射的根据就是我按钮按下传入的参数。

这样就可以做到一个页面显示tab。

 

这篇关于Caliburn.Micro框架学习笔记——多页面处理案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023229

相关文章

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

5 种使用Python自动化处理PDF的实用方法介绍

《5种使用Python自动化处理PDF的实用方法介绍》自动化处理PDF文件已成为减少重复工作、提升工作效率的重要手段,本文将介绍五种实用方法,从内置工具到专业库,帮助你在Python中实现PDF任务... 目录使用内置库(os、subprocess)调用外部工具使用 PyPDF2 进行基本 PDF 操作使用

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

Python异常处理之避免try-except滥用的3个核心原则

《Python异常处理之避免try-except滥用的3个核心原则》在Python开发中,异常处理是保证程序健壮性的关键机制,本文结合真实案例与Python核心机制,提炼出避免异常滥用的三大原则,有需... 目录一、精准打击:只捕获可预见的异常类型1.1 通用异常捕获的陷阱1.2 精准捕获的实践方案1.3

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2