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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]