在前面的Silverlight实战示例7(兼集合属性的妙用)系列中,我们模拟了一个复杂实体的处理,这个复杂实体类似于aspnet的Datatable,但不是很完全,这里我们增加一些代码,使得这种模拟更纯粹:
1、在Dynamicdatafield里增加public DynamicdaTarow Row { get; set; }属性,保持对所在行的引用
2、在DynamicdaTarow中增加public Dynamicdatatable table { get; set; }属性,保持对表的引用
3、在Dynamicdatatable里增加public event PropertyChangedEventHandler PropertyChanged;(可根据自己需要定义自己的委托与事件)
4、在Dynamicdatafield.Shared.cs里,修改成如下:
public partial class Dynamicdatafield
{
public object Value
{
get
{
if (this.DataType == "datatime")
{
return this.DTValue;
}
if (this.DataType == "byte[]")
{
return this.ByteArrayValue;
}
//在这里可以做参照处理接口.
return this.StrValue;
}
set
{
if (this.DataType == "datatime")
{
DTValue = (DateTime) value;
}
if (this.DataType == "byte[]")
{
this.ByteArrayValue =(byte[])value;
}
this.StrValue = value.ToString();
//注意这里调用表的事件.
if (this.Row.table.PropertyChanged != null)
{
this.Row.table.PropertyChanged(this,new System.ComponentModel.PropertyChangedEventArgs(this.FIEldname));
}
}
}
}
5、构造表的时候注意将实体关系赋值。
6、客户端获取数据时将事件关联上
/// <summary>
/// 数据加载.
/// </summary>
private voID LoadData()
{
theS.GetDynamicdatatable("select * from EmployeeInfo ",op =>
{
if (op.HasError == false)
{
DataSource = op.Value.Rows;
Datatable = op.Value;
//关联事件
Datatable.PropertyChanged += new PropertyChangedEventHandler(datafieldChanged);
}
else
{
MessageBox.Show(op.ErrorMsg);
}
},null);
}
private voID datafieldChanged(object sender,PropertyChangedEventArgs e)
{
//...................事件处理
}
这样我们的Dynamicdatatable就是一个简单的类似Datatable的东西。增加事件的好处就是可以免除很多UI事件的处理,从而使得MVVM模式更加容易.
总结以上是内存溢出为你收集整理的给动态数据集的字段值变化加事件,更好的模拟DataTable全部内容,希望文章能够帮你解决给动态数据集的字段值变化加事件,更好的模拟DataTable所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)