解耦!解耦!漫谈 XAML 应用程序开源框架 Prism(六)MVVM

2024-03-26 15:38

本文主要是介绍解耦!解耦!漫谈 XAML 应用程序开源框架 Prism(六)MVVM,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

一、MVVM - 视图 与 后台逻辑 的解耦

介绍MVVM是什么的文章很多,这里不再赘述,需要说明的是听到很多这样的说法:Prism就是MVVM框架,我觉得这样的说法是不对的,MVVM只是Prism框架中的一部分,是Prism解耦家族的一员。

这里简单介绍一下在Prism中的一些关于MVVM相关小技巧。

在Visual Studio 中有Prism Template Pack扩展,安装它之后可以更方便的帮助我们创建Prism程序模板,还会提供一些快捷代码段的支持,比如propp快速创建一个带通知的属性,cmd创建一个命令。

Binding是MvvM中最重要的概念,视图元素之间,视图与模型之间简单数据,集合数据,指令,指令参数等等都可以Binding。Binding非常的灵活,但我们必须认真思考它的本质。

在MVVM中最重的事情就是揣度筹划各种任务的执行单元,同样一个功能因为实现的方法太多,反而更容易违背框架的设计初衷。比如视图的外观可以绑定在模型中去控制,这在有些场合是合适的,有些场合更适合在视图中实现。

二、Binding

视图元素之间

<TextBlock Text="{Binding ElementName=SL_Bat1, Path=Value}" /><Slider Name="SL_Bat1"></Slider>

视图与模型之间简单数据 Binding 并格式化

视图

<TextBlock Text="{Binding SiftContrast, StringFormat={}{0:F3}}" />

模型

        private double _SiftContrast = 0.04;public double SiftContrast{get { return _SiftContrast; }set { SetProperty(ref _SiftContrast, value); }}

集合数据Binding

效果:

 视图

            <DataGridWidth="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Grid}, AncestorLevel=1}, Path=ActualWidth}"Height="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type Grid}, AncestorLevel=1}, Path=ActualHeight}"HorizontalAlignment="Center"VerticalAlignment="Center"AutoGenerateColumns="False"CanUserAddRows="False"ItemsSource="{Binding Model.UserList}"ScrollViewer.VerticalScrollBarVisibility="Auto"><DataGrid.Columns><DataGridTextColumnWidth="200"Binding="{Binding Name}"Header="用户"IsReadOnly="True" /><DataGridTextColumnWidth="200"Binding="{Binding Authority}"Header="权限"IsReadOnly="True" /><DataGridTemplateColumn><DataGridTemplateColumn.CellTemplate><DataTemplate><StackPanel Orientation="Horizontal"><Button Command="{Binding Delete}" Content="删 除" /></StackPanel></DataTemplate></DataGridTemplateColumn.CellTemplate></DataGridTemplateColumn><DataGridTemplateColumn><DataGridTemplateColumn.CellTemplate><DataTemplate><StackPanel Orientation="Horizontal"><Button Command="{Binding ChangePassword}" Content="修改密码" /></StackPanel></DataTemplate></DataGridTemplateColumn.CellTemplate></DataGridTemplateColumn></DataGrid.Columns></DataGrid>

 模型

        private BindingList<User> _UserList = new();public BindingList<User> UserList{get { return _UserList; }set { SetProperty(ref _UserList, value); }}public class User{public User(string name, string password, Authority authority){Name = name;Password = password;Authority = authority;}public string Name { get; set; }public string Password { get; set; }public Authority Authority { get; set; }private DelegateCommand _Delete;public DelegateCommand Delete =>_Delete ??= new DelegateCommand(ExecuteDelete);void ExecuteDelete(){DeleteMe?.Invoke(Name);}public event Action<string> DeleteMe;private DelegateCommand _ChangePassword;public DelegateCommand ChangePassword =>_ChangePassword ??= new DelegateCommand(ExecuteChangePassword);void ExecuteChangePassword(){ChangeMyPassword?.Invoke(Name);}public event Action<string> ChangeMyPassword;public override string ToString(){return $"{Name}";}}

命令Binding

这里把一个控件做为参数传给模型

            <ButtonWidth="80"Height="28"HorizontalAlignment="Center"Background="#5cb85c"Command="{Binding LoginCommand}"CommandParameter="{Binding ElementName=passwordBox}"Content="登录"FontSize="12"Foreground="White" Cursor="Hand" />

 模型获得参数

        public DelegateCommand<PasswordBox> LoginCommand =>_LoginCommand ??= new DelegateCommand<PasswordBox>(ExecuteLoginCommand);private async void ExecuteLoginCommand(PasswordBox passwordBox){var password = passwordBox.Password;...}

示例就不放更多了,弄清楚wpf Binding相关的一些概念比如DataContext、依赖属性、ItemsSource是学习使用MvvM框架的关键。

这篇关于解耦!解耦!漫谈 XAML 应用程序开源框架 Prism(六)MVVM的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1