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

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

public string Name { get; set; }

871381-20191008182809779-370734108.png
然后去UI的xaml文件中binding一下:
871381-20191008182918237-729277908.png
此时运行程序是不会得到我们想要的结果的,因为还没有设置DataContext。
我们去设置下DataContext:
871381-20191008183202568-1042381269.png
debug下,按理说UI的button会找到DataContext的Name属性,显示我们的MainViewModel.Name
871381-20191008183245615-1070400768.png
关于绑定的最好的事情之一是它们使UI与视图模型中的数据保持同步。但是此时我们更改FirstName属性,UI上是不会跟随同步的,因为我们的MainViewModel虽然继承了INotifyPropertyChanged接口但是我们并没有应用。为了实现修改mainViewModel中的属性值后就自动更新到UI上,我们需要应用该接口:
871381-20191008190335351-1097189588.png
然后,为button创建个事件,当按钮按下后修改MainViewModel的name属性:
871381-20191008190500853-2089599487.png
871381-20191008190518363-2049469058.png
debug下试试:
871381-20191008190648428-1753477218.gif
但是,记住每次更改属性值时都会引发事件,这会非常繁琐。由于这种模式非常普遍,因此许多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事件

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

转载于:https://www.cnblogs.com/feipeng8848/p/11637217.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值