解耦!解耦!漫谈 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

相关文章

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

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

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统