在前面的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模式更加容易.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。