项目中列行的数据 都需要动态生成 所以考虑到对象绑定 可需要一个动态生成属性的意思
缺点 加载速度会慢 很明显的慢
解决办法 尽量减轻动态属性的量~
参考文章
DynamicObject 在WPF 中的应用 - Lee's Blog - 博客园(这个没看明白 但是冥冥中让我觉得 收藏一下以后可能会用)
代码
属性类 想研究明白的 看参考文章
public class NurseScheduleStatisticsModel : DynamicObject
{
Dictionary<string, object> Properties = new Dictionary<string, object>();
public override bool TrySetMember(SetMemberBinder binder, object value)
{
if (!Properties.Keys.Contains(binder.Name))
{
Properties.Add(binder.Name, value.ToString());
}
return true;
}
public override bool TryGetMember(GetMemberBinder binder, out object result)
{
return Properties.TryGetValue(binder.Name, out result);
}
}
生成临时数据
private ObservableCollection<NurseScheduleStatisticsModel> GetNameDataLlist()
{
dynamic model = new NurseScheduleStatisticsModel();
model.Name = "市川 賞子";
model.Class_ = "B";
model.JOb = "リーダー";
model.Num = "1";
model.Num1 = "r1";
model.Num2 = "R1";
model.Num3 = "r1";
model.Num4 = "r1";
model.Num5 = "T1";
dynamic model2 = new NurseScheduleStatisticsModel();
model2.Name = "石田";
model2.Class_ = "B";
model2.JOb = "リーダー";
model2.Num = "2";
model2.Num1 = "r2";
model2.Num2 = "R2";
model2.Num3 = "r3";
model2.Num4 = "r2";
model2.Num5 = "T2";
dynamic model3 = new NurseScheduleStatisticsModel();
model3.Name = "安达 鮎美";
model3.Num = "3";
model3.Class_ = "B";
model3.JOb = "リーダー";
model3.Num1 = "r2";
model3.Num2 = "R3";
model3.Num3 = "r2";
model3.Num4 = "r3";
model3.Num5 = "T3";
modelList.Add(model);
modelList.Add(model2);
modelList.Add(model3);
return modelList;
}
动态增加列和绑定datagrid
dl.Binding = new Binding("Num" + (i + 1) );
这里的bing 绑定的就是对象里的Num1~开始的对象
for (int i = 0; i < 10; i++)
{
DataGridTextColumn dl = new DataGridTextColumn();
dl.Header='num'+i;
dl.Binding = new Binding("Num" + (i + 1) );
dataGrid.Columns.Add(dl);
}
dataGrid.ItemsSource = GetNameDataLlist();
我在项目里 使用一个自定义对象 来包含 dynamic 动态对象 减少不必要的开销
对象
public class NameList : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
public NameList(string name, string jOb, string class_, int num, NurseScheduleStatisticsModel model) { Name = name; Class_ = class_; JOb = jOb; Num = num; Ml = model; }
private string name;
public string Name
{
get { return name; }
set
{
name = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("Name"));
}
}
}
private int num;
public int Num
{
get { return num; }
set
{
num = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("Num"));
}
}
}
private string class_;
public string Class_
{
get { return class_; }
set
{
class_ = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("Class_"));
}
}
}
private string jOb;
public string JOb
{
get { return jOb; }
set
{
jOb = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("JOb"));
}
}
}
private NurseScheduleStatisticsModel ml;
public NurseScheduleStatisticsModel Ml
{
get { return ml; }
set { ml = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("Ml"));
}
}
}
}
模拟数据
private ObservableCollection<NameList> GetNameDataLlist2()
{
dynamic model = new NurseScheduleStatisticsModel();
model.Num1 = "r1";
model.Num2 = "R1";
model.Num3 = "r1";
model.Num4 = "r1";
model.Num5 = "T1";
dynamic model2 = new NurseScheduleStatisticsModel();
model2.Num1 = "r2";
model2.Num2 = "R2";
model2.Num3 = "r3";
model2.Num4 = "r2";
model2.Num5 = "T2";
dynamic model3 = new NurseScheduleStatisticsModel();
model3.Num1 = "r2";
model3.Num2 = "R3";
model3.Num3 = "r2";
model3.Num4 = "r3";
model3.Num5 = "T3";
//modelList.Add(model);
//modelList.Add(model2);
//modelList.Add(model3);
listName.Add(new NameList("市川 賞子", "リーダー", "B", 1, model));
listName.Add(new NameList("石田", "リーダー", "C", 2, model2));
listName.Add(new NameList("安达 鮎美", "リーダー", "C", 3, model3));
return listName;
}
绑定动态列
需要在套一层Ml对象来引用
for (int i = 0; i < LS.Count; i++)
{
DataGridTextColumn dl = new DataGridTextColumn();
dl.Header=LS[i];
dl.Binding = new Binding("Ml.Num" + (i + 1) );
dataGrid.Columns.Add(dl);
}
就是慢 的有这点数据量就要4秒~6秒 loading加载提示肯定是要有了
希望有人有更好 更成熟的方法