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

public string Name { get; set; }



然后去UI的xaml文件中binding一下:



此时运行程序是不会得到我们想要的结果的,因为还没有设置DataContext。

我们去设置下DataContext:



debug下,按理说UI的button会找到DataContext的Name属性,显示我们的MainViewModel.Name



关于绑定的最好的事情之一是它们使UI与视图模型中的数据保持同步。但是此时我们更改FirstName属性,UI上是不会跟随同步的,因为我们的MainViewModel虽然继承了INotifyPropertyChanged接口但是我们并没有应用。为了实现修改mainViewModel中的属性值后就自动更新到UI上,我们需要应用该接口:



然后,为button创建个事件,当按钮按下后修改MainViewModel的name属性:





debug下试试:



但是,记住每次更改属性值时都会引发事件,这会非常繁琐。由于这种模式非常普遍,因此许多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/

最新文章

  1. 简述id,instancetype和__kindof的区别
  2. innobackupex --rsync 报错 Error: can&#39;t create file (null)/xtrabackup_rsyncfiles_pass1
  3. TCMalloc 安装和使用
  4. GDB代码调试与使用
  5. android模拟器(genymotion)+appium+python 框架执行过程中问题解答
  6. The Introduction of Java Memory Leaks
  7. [转帖]FPGA--Vivado
  8. (一)《Java编程思想》学习——按位运算符、移位运算符
  9. poj 1759 Garland (二分搜索之其他)
  10. 截取字符串一之slice
  11. iOS-Core-Animation-Advanced-Techniques(一)
  12. Linux入门(3)——Ubuntu16.04下安装VMware
  13. python中logging模块
  14. 同一个机器 安装多个版本Chrome浏览器的方法
  15. hadoop伪分布环境快速搭建
  16. centos6安装配置zabbix3主控端
  17. EOJ2018.10 月赛
  18. LPC43xx SGPIO Experimentation
  19. Swing获取字符串的宽度和高度
  20. en_a

热门文章

  1. JavaWeb_(Spring框架)Spring中IoC与DI概念入门
  2. Flask-login Question
  3. vue+webpack 实现懒加载的三种方式
  4. Android中利用jsoup解析html页面
  5. thinkphp模版主题使用方法
  6. computer5 environment
  7. Python生成随机数组的方法小结
  8. SparkMLLib的简单学习
  9. Jmeter 逻辑控制器 之 循环控制器
  10. C#使用MPI进行高性能计算