InotifyPropertyChanged接口实现简单数据绑定
2013-03-05 19:27
399 查看
UI跟踪对象变化的一种常用方式就是在对象属性发生变化时触发相关的事件。为此对象就必须实现InotifyPropertyChanged接口。
在Msdn上是这样描述的:向客户端发出某一属性值已更改的通知。
下面看一个例子:
public class Person: InotifyPropertyChanged
{
public eventPropertyChangedEventHandler propertyChanged;
protected voidNotify(string propName)
{
if(this.PropertyChanged!=null)
{
propertyChanged(this,newpropertyChangedEventArgs(propName));
}
}
string name;
public stringName
{
get{return this.name;}
set
{
if(this.name==value){return;}
this.name=value;
Notify(“Name”);
}
}
intage;
publicint Age
{
get{return this.age;}
set
{
if(this.age==value){return;}
this.age=value;
Notify(“Age”);
}
}
}
当Person对象属性发生变化时,Person类就会触发PropertyChanged事件,利用此事件可以让textbox的内容和Person类的属性值保持同步。
具体实现如下:
Class Window1:Window
{
Person person =new Person(“Tom”,11);
Person.PropertyChanged+=person_PropertyChanged;
}
Void person_PropertyChanged(objectsender,PropertyChangedEventArgs e)
{
switch(e.PropertyName)
{
case “Name”:
this.nameTextBox.Text=person.Name;
bresk;
case “Age”:
this.ageTextBox.Text=person.Age;
break;
}
}
这里注册了person类属性的变更事件PropertyChanged,从而保证了文本框和对象属性的同步。需要注意的是,用户修改控件TextBox的内容时person对象的属性不会发生变化,需要使用TextChanged事件对person类属性进行变更。
在Msdn上是这样描述的:向客户端发出某一属性值已更改的通知。
下面看一个例子:
public class Person: InotifyPropertyChanged
{
public eventPropertyChangedEventHandler propertyChanged;
protected voidNotify(string propName)
{
if(this.PropertyChanged!=null)
{
propertyChanged(this,newpropertyChangedEventArgs(propName));
}
}
string name;
public stringName
{
get{return this.name;}
set
{
if(this.name==value){return;}
this.name=value;
Notify(“Name”);
}
}
intage;
publicint Age
{
get{return this.age;}
set
{
if(this.age==value){return;}
this.age=value;
Notify(“Age”);
}
}
}
当Person对象属性发生变化时,Person类就会触发PropertyChanged事件,利用此事件可以让textbox的内容和Person类的属性值保持同步。
具体实现如下:
Class Window1:Window
{
Person person =new Person(“Tom”,11);
Person.PropertyChanged+=person_PropertyChanged;
}
Void person_PropertyChanged(objectsender,PropertyChangedEventArgs e)
{
switch(e.PropertyName)
{
case “Name”:
this.nameTextBox.Text=person.Name;
bresk;
case “Age”:
this.ageTextBox.Text=person.Age;
break;
}
}
这里注册了person类属性的变更事件PropertyChanged,从而保证了文本框和对象属性的同步。需要注意的是,用户修改控件TextBox的内容时person对象的属性不会发生变化,需要使用TextChanged事件对person类属性进行变更。
相关文章推荐
- InotifyPropertyChanged接口实现简单数据绑定
- 不实现 INotifyPropertyChanged接口也能实现数据绑定
- Silverlight 实现INotifyPropertyChanged接口绑定数据
- 黑马程序员_数据绑定,INotifyPropertyChanged接口,DataContext
- SilverLight学习笔记--Silverlight中INotifyPropertyChanged 接口在数据绑定中的使用
- SilverLight 学习笔记--Silverlight中INotifyPropertyChanged 接口在数据绑定中的使用
- Seliverlight 中数据绑定INotifyPropertyChanged 接口的用法 .数据绑定IValueConvert的用法学习笔记
- 【黑马程序员】数据绑定的INotifyPropertyChanged接口:监听和同步
- 利用 JavaScript 数据绑定实现一个简单的 MVVM 库
- SliverLight使用ObservableCollection和INotifyPropertyChanged绑定数据
- 实现非常简单的js双向数据绑定
- 数据之一次绑定, 单向绑定, 双向绑定, INotifyPropertyChanged, 数据转换, 数据验证(转)
- WPF入门(四)-WPF+LINQ实现数据绑定、交互及简单datagrid样式
- WPF系列之三:实现类型安全的INotifyPropertyChanged接口,可以不用“Magic string” 么?
- 五十行javascript代码实现简单的双向数据绑定
- WPF Label控件在数据绑定Content属性变化触发TargetUpdated事件简单实现类似TextChanged 事件效果
- 实现数据双向绑定最简单的方式
- Android中简单实现Spinner的数据绑定
- 使用原生js onkeyup+jQuery实现简单的双向数据绑定
- JavaScript数据绑定实现一个简单的 MVVM 库