网站LOGO
凉月十七
页面加载中
12月21日
网站LOGO 凉月十七
 
菜单
  • 用户的头像
    首次访问
    上次留言
    累计留言
    我的等级
    我的角色
    打赏二维码
    打赏博主
    (三)WPF桌面程序开发——学习WPF中的MVVM技术思想
    点击复制本页信息
    微信扫一扫
    文章二维码
    文章图片 文章标题
    创建时间
  • 一 言
    确认删除此评论么? 确认
  • 本弹窗介绍内容来自,本网站不对其中内容负责。

    (三)WPF桌面程序开发——学习WPF中的MVVM技术思想

    凉月十七 · 原创 ·
    WPF · 暂无标签
    共 4229 字 · 约 1 分钟 · 278

    前言

    有几周没更新了,用WPF写了一套桌面软件,实现GerBer文件的图像处理,渲染出真实的板卡图像
    Gerber渲染软件Gerber渲染软件


    关于MVVM

    MVVM是Model-View-ViewModel的简写,是一种架构模式,其设计目标是从视图层中移除几乎所有的代码,促进UI开发和业务代码的分离,即前后端分离。使得代码的开发、更新和复用更加简单、快捷。

    • View 是指可见元素和用户输入功能,包括用户界面、动画和文本。View中的内容不能直接通过交互来更改所呈现的内容,其交互逻辑应当在ViewModel中实现。
    • ViewModel位于View层和Model层之间,这里存放了与View交互的代码逻辑,利用Binding命令可将View中的UI元素与ViewModel中的控件连接起来。
    • Model是指数据模型,ViewModel能够调用设计好的数据模型。
    MVVM架构图MVVM架构图

    一份简单的MVVM示例

    • Model
    Model 代码:
        namespace WpfMvvmExample.Models
    {
        public class Person
        {
            public string Name { get; set; }  // 存储人名的属性
        }
    }
    
    • ViewModel
    ViewModel 代码:
    using System.ComponentModel;
    using System.Runtime.CompilerServices;
    using System.Windows.Input;
    using WpfMvvmExample.Models;
    
    namespace WpfMvvmExample.ViewModels
    {
        public class MainViewModel : INotifyPropertyChanged
        {
            private Person person = new Person();  // 实例化Person模型
            private string greeting;  // 用于存储问候语的私有字段
    
            public string Name
            {
                get { return person.Name; }
                set
                {
                    person.Name = value;
                    OnPropertyChanged();  // 触发属性更改通知
                }
            }
    
            public string Greeting
            {
                get { return greeting; }
                private set
                {
                    greeting = value;
                    OnPropertyChanged();  // 触发属性更改通知
                }
            }
    
            public ICommand ShowGreetingCommand { get; }  // 命令,用于显示问候语
    
            public MainViewModel()
            {
                ShowGreetingCommand = new RelayCommand(ShowGreeting);  // 初始化命令并绑定方法
            }
    
            private void ShowGreeting()
            {
                Greeting = $"Hello, {Name}!";  // 设置问候语
            }
    
            public event PropertyChangedEventHandler PropertyChanged;
    
            protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
            {
                PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));  // 通知视图属性已更改
            }
        }
    }
    
    • View
    View 代码:
    <Window x:Class="WpfMvvmExample.MainWindow"
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
            xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
            xmlns:local="clr-namespace:WpfMvvmExample"
            mc:Ignorable="d"
            Title="MVVM Example" Height="200" Width="300">
        <Window.DataContext>
            <local:ViewModels.MainViewModel/>  <!-- 设置数据上下文为MainViewModel -->
        </Window.DataContext>
        <StackPanel Margin="10">
            <TextBox Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" Margin="0,0,0,10"/>  <!-- 绑定文本框到Name属性 -->
            <Button Content="Say Hello" Command="{Binding ShowGreetingCommand}" Margin="0,0,0,10"/>  <!-- 绑定按钮到命令 -->
            <TextBlock Text="{Binding Greeting}"/>  <!-- 绑定TextBlock到Greeting属性 -->
        </StackPanel>
    </Window>
    
    • ReadyCommand

    在使用MVVM架构开发时,应当实现ICommand接口,这样视图上的元素就可以绑定到命令逻辑上,从而实现前后端的解耦

    ReadyCommand 代码:
    using System;
    using System.Windows.Input;
    
    namespace WpfMvvmExample.ViewModels
    {
        public class RelayCommand : ICommand
        {
            private readonly Action execute;
            private readonly Func<bool> canExecute;
    
            public RelayCommand(Action execute, Func<bool> canExecute = null)
            {
                this.execute = execute;
                this.canExecute = canExecute ?? (() => true);  // 如果没有提供canExecute参数,将默认为总是可执行
            }
    
            public event EventHandler CanExecuteChanged
            {
                add { CommandManager.RequerySuggested += value; }
                remove { CommandManager.RequerySuggested -= value; }
            }
    
            public bool CanExecute(object parameter)
            {
                return canExecute();
            }
    
            public void Execute(object parameter)
            {
                execute();  // 执行绑定的Action
            }
        }
    }
    
    声明:本文由 凉月十七(博主)原创,依据 CC-BY-NC-SA 4.0 许可协议 授权,转载请注明出处。

    还没有人喜爱这篇文章呢

    现在已有

    2

    条评论
    发一条!
    1. 头像
      justin
      头像 justin
      • 等级:Lv.1
      • 角色:访客
      • 在线:本月

      gerber呢?

      1. 头像
        凉月十七 justin

        嗯嗯?

    博客logo 凉月十七  
    MOEICP 萌ICP备20240420号 ICP 粤ICP备2024236063号

    🕛

    本站已勉强运行 245 天 21 小时 45 分

    🌳

    by MyLife
    凉月十七. © 2024 ~ 2024.
    网站logo

    凉月十七  
     
     
     
     
    壁纸