博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WPF中INotifyPropertyChanged用法与数据绑定
阅读量:5121 次
发布时间:2019-06-13

本文共 3508 字,大约阅读时间需要 11 分钟。

在WPF中进行数据绑定的时候常常会用到INotifyPropertyChanged接口来进行实现,下面来看一个INotifyPropertyChanged的案例。

下面定义一个Person类:

[csharp] 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.ComponentModel;  
  6.   
  7. namespace WpfApp  
  8. {  
  9.     public class Person:INotifyPropertyChanged  
  10.     {  
  11.         private String _name = "张三";  
  12.         private int _age = 24;  
  13.         private String _hobby = "篮球";  
  14.             
  15.         public String Name  
  16.         {  
  17.             set  
  18.             {  
  19.                 _name = value;  
  20.                 if (PropertyChanged != null)//有改变  
  21.                 {  
  22.                     PropertyChanged(thisnew PropertyChangedEventArgs("Name"));//对Name进行监听  
  23.                 }  
  24.             }  
  25.             get  
  26.             {  
  27.                 return _name;  
  28.             }  
  29.         }  
  30.   
  31.         public int Age  
  32.         {  
  33.             set  
  34.             {  
  35.                 _age = value;  
  36.                 if (PropertyChanged != null)  
  37.                 {  
  38.                     PropertyChanged(thisnew PropertyChangedEventArgs("Age"));//对Age进行监听  
  39.                 }  
  40.             }  
  41.             get  
  42.             {  
  43.                 return _age;  
  44.             }   
  45.         }  
  46.         public String Hobby//没有对Hobby进行监听  
  47.         {  
  48.             get { return _hobby; }  
  49.             set { _hobby = value; }  
  50.         }  
  51.         public event PropertyChangedEventHandler PropertyChanged;  
  52.     }  
  53. }  
上面定义的这个Person类中,对Name和Age属性进行了监听,但是没有对Hobby进行监听。

MainWindow.xmal界面文件定义的内容如下:

[csharp] 
 
  1. <Window x:Class="WpfApp.MainWindow"  
  2.         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
  3.         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
  4.         Title="MainWindow" Height="300" Width="350">  
  5.     <Grid Name="grid">   
  6.         <TextBox Height="20" Text="{Binding Path=Name}"  HorizontalAlignment="Left" Margin="63,12,0,0" Name="textBox1" VerticalAlignment="Top" Width="139" />  
  7.         <TextBox Height="20"  Text="{Binding Path=Age}"  HorizontalAlignment="Left" Margin="63,48,0,0" Name="textBox2" VerticalAlignment="Top" Width="139" />  
  8.         <TextBox Height="20" Text="{Binding Path=Hobby}"  HorizontalAlignment="Left" Margin="63,82,0,0" Name="textBox3" VerticalAlignment="Top" Width="139" />  
  9.           
  10.         <Button Content="显示用户信息" Height="26" HorizontalAlignment="Left" Margin="60,118,0,0" Name="button1" VerticalAlignment="Top" Width="144" Click="button1_Click" />  
  11.         <Button Content="修改用户信息" Height="26" HorizontalAlignment="Left" Margin="60,158,0,0" Name="button2" VerticalAlignment="Top" Width="144" Click="button2_Click" />  
  12.   
  13.         <TextBlock Height="40" HorizontalAlignment="Left" Margin="13,201,0,0" Name="textBlock1"   Text="{Binding Path=Name}"  VerticalAlignment="Top" Width="88" />  
  14.         <TextBlock Height="40" HorizontalAlignment="Left" Margin="118,201,0,0" Name="textBlock2" Text="{Binding Path=Age}" VerticalAlignment="Top" Width="88" />  
  15.         <TextBlock Height="40" HorizontalAlignment="Left" Margin="222,201,0,0" Name="textBlock3" Text="{Binding Path=Hobby, Mode=TwoWay}" VerticalAlignment="Top" Width="88" />  
  16.     </Grid>  
  17. </Window>  

后台代码是:

[csharp] 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Windows;  
  6. using System.Windows.Controls;  
  7. using System.Windows.Data;  
  8. using System.Windows.Documents;  
  9. using System.Windows.Input;  
  10. using System.Windows.Media;  
  11. using System.Windows.Media.Imaging;  
  12. using System.Windows.Navigation;  
  13. using System.Windows.Shapes;  
  14.   
  15. namespace WpfApp  
  16. {  
  17.     /// <summary>  
  18.     /// MainWindow.xaml 的交互逻辑  
  19.     /// </summary>  
  20.     public partial class MainWindow : Window  
  21.     {  
  22.         public MainWindow()  
  23.         {  
  24.             InitializeComponent();  
  25.         }  
  26.   
  27.         private Person p1 = new Person();  
  28.         private void button1_Click(object sender, RoutedEventArgs e)  
  29.         {  
  30.             grid.DataContext = p1;//绑定数据  
  31.             p1.Name = "李四";   
[csharp] 
 
  1.             p1.Hobby = "足球";  
  2.         }   
  3.         private void button2_Click(object sender, RoutedEventArgs e)  
  4.         {     
  5.             p1.Age = p1.Age + 1;  
  6.             p1.Hobby = "足球";  
  7.         }  
  8.     }  
  9. }  

当点击显示用户数据的时候

下面看看这些信息具体都来自于哪儿?

由于在Person中没有对Hobby进行监听,所以p1.Hobby="足球"这个语句没有起到作用。 点击修改用户信息的时候也是不能修改绑定到界面上的对应Hobby的信息(即使是在界面处写了Mode=TwoWay,也是不能进行绑定的)。

所以使用INotifyPropertyChanged的时候,需要对要进行绑定的属性进行显示的设置的,否则绑定的时候是不能进行双向绑定的,即绑定是无效的。

转载于:https://www.cnblogs.com/dxmfans/p/9434892.html

你可能感兴趣的文章
距离公式汇总以及Python实现
查看>>
一道不知道哪里来的容斥题
查看>>
Window7上搭建symfony开发环境(PEAR)
查看>>
Linux内核态、用户态简介与IntelCPU特权级别--Ring0-3
查看>>
第23月第24天 git命令 .git-credentials git rm --cached git stash clear
查看>>
java SE :标准输入/输出
查看>>
一些方便系统诊断的bash函数
查看>>
jquery中ajax返回值无法传递到上层函数
查看>>
css3之transform-origin
查看>>
Master选举原理
查看>>
[ JAVA编程 ] double类型计算精度丢失问题及解决方法
查看>>
小别离
查看>>
好玩的-记最近玩的几个经典ipad ios游戏
查看>>
PyQt5--EventSender
查看>>
Sql Server 中由数字转换为指定长度的字符串
查看>>
Java 多态 虚方法
查看>>
万能的SQLHelper帮助类
查看>>
tmux的简单快捷键
查看>>
[Swift]LeetCode922.按奇偶排序数组 II | Sort Array By Parity II
查看>>
《绿色·精简·性感·迷你版》易语言,小到不可想象
查看>>