WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)

摘要:
接下来,我们在MainViewModel类中创建一个属性:publicstringName{get;set;}然后转到UI的xaml文件进行绑定:此时运行程序将无法获得我们想要的结果,因为尚未设置DataContext。让我们设置DataContext:在调试下,UI按钮将找到DataContext的Name属性,并显示有关MainViewModel.Name的信息

接上篇,我们在MainViewModel类中创建个属性:

public string Name { get; set; }

WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第1张
然后去UI的xaml文件中binding一下:
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第2张
此时运行程序是不会得到我们想要的结果的,因为还没有设置DataContext。
我们去设置下DataContext:
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第3张
debug下,按理说UI的button会找到DataContext的Name属性,显示我们的MainViewModel.Name
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第4张
关于绑定的最好的事情之一是它们使UI与视图模型中的数据保持同步。但是此时我们更改FirstName属性,UI上是不会跟随同步的,因为我们的MainViewModel虽然继承了INotifyPropertyChanged接口但是我们并没有应用。为了实现修改mainViewModel中的属性值后就自动更新到UI上,我们需要应用该接口:
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第5张
然后,为button创建个事件,当按钮按下后修改MainViewModel的name属性:
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第6张
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第7张
debug下试试:
WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)第8张
但是,记住每次更改属性值时都会引发事件,这会非常繁琐。由于这种模式非常普遍,因此许多MVVM框架为您的视图模型类提供了一个基类,类似于以下内容:

public abstract class ViewModelBase : INotifyPropertyChanged
{
    public event PropertyChangedEventHandler PropertyChanged;
 
    protected bool SetProperty<T>(ref T field, T newValue, [CallerMemberName]string propertyName = null)
    {
        if(!EqualityComparer<T>.Default.Equals(field, newValue))
        {
            field = newValue;
            PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
            return true;
        }
        return false;
    }
}

这使我们可以像这样重写Name属性:

public class ViewModel : ViewModelBase
{
    private string name;
    public string Name
    {
        get => name;
        set => SetProperty(ref name, value);
    }
}

每次我们更改Name属性时,都会引发INPC事件

工程源代码上传在GitHub上了:https://github.com/feipeng8848/WPF-Demo

参考资料:
https://intellitect.com/getting-started-model-view-viewmodel-mvvm-pattern-using-windows-presentation-framework-wpf/

免责声明:文章转载自《WPF入门(2)——数据绑定与INotifyPropertyChanged(INPC)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇WIN7无法访问共享打印机及文件的解决办法虚拟机三种磁盘置备方式下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

认识WPF

新开一节WPF桌面开发的讲解,这节先初步认识一下什么是WPF。 1.简介 WPF是 Windows Presentation Foundation 的英文缩写,意为“窗体呈现基础”,是微软基于.NET Framework 3.0 推出的新一代构建窗体程序的框架。不同于WinForm,WPF实现了界面和开发分离,它的界面是由Xaml语言构建的,这种形式对前端...

WPF学习笔记二 WPF命中测试

概述: WPF中的Canvas是常用的一个绘图控件,可以方便地在Canvas中添加我们需要处理的各种元素如:图片、文字等。但Canvas中元素增加到一定数量,并且有重合的时候,我们如何通过在Canvas中点击鼠标,获得我们想要的元素,然后再对该元素做出相应的控制? 命中测试,可以很好地解决这个问题 本文目的: 使用命中测试,选取Canvas中相应Ele...

【WPF学习】第五十五章 基于路径的动画

  基于路径的动画使用PathGeometry对象设置属性。尽管原则上基于路径的动画也能用于修改任何适当数据类型的属性,但当动态改变与位置相关的属性时最有用。实际上,基于路径的动画类主要用于帮助沿着一条路径移动可视化对象。   正如在“【WPF学习】第四十三章 路径和几何图形”学过的,PathGeometry对象描述可包含直线、弧线以及曲线的图形。下图显示...

wpf数据绑定更新通知

类似于这样子的;大致的意思是:一个代码变量,通过改变变量的值,绑定这个变量的这个圆颜色也在变化 就是一种心跳效果 在网上数据触发的感觉不多,废了不少时间,这里做个总结 1:通知 class NotifyBase : INotifyPropertyChanged { public event PropertyChangedEve...

WPF/Silverlight HierarchicalDataTemplate 模版的使用

上一篇 对Wpf/Silverlight Template 进行了总结,本篇继续上一篇,主要是介绍 HierarchicalDataTemplate 的使用方法。HierarchicalDataTemplate 继承于DataTemplate,被称之为"层级式数据模板",主要是应用层级比较明显数据集合,其典型的应用就是对TreeView控件进行数据绑定,接...

DevExpress WPF界面控件

DevExpress WPF套件提供了Reveal Highlight和Acrylic效果 - 这些外观选项旨在模仿Windows UI应用程序的外观和样式。 DevExpress WPF v21.1高速下载 Reveal Highlight 使用RevealHighlightOptions静态类添加Reveal Highlight效果,您可以将此效果添加...