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

相关文章

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid

Python实现自动化接收与处理手机验证码

《Python实现自动化接收与处理手机验证码》在移动互联网时代,短信验证码已成为身份验证、账号注册等环节的重要安全手段,本文将介绍如何利用Python实现验证码的自动接收,识别与转发,需要的可以参考下... 目录引言一、准备工作1.1 硬件与软件需求1.2 环境配置二、核心功能实现2.1 短信监听与获取2.

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详