项目中列行的数据 都需要动态生成 所以考虑到对象绑定 可需要一个动态生成属性的意思
缺点 加载速度会慢 很明显的慢
解决办法 尽量减轻动态属性的量~
参考文章
https://www.cnblogs.com/maomiyouai/p/3594132.html
https://www.cnblogs.com/dingli/archive/2012/06/14/2548687.html(这个没看明白 但是冥冥中让我觉得 收藏一下以后可能会用)
代码
属性类 想研究明白的 看参考文章
-
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加载提示肯定是要有了
希望有人有更好 更成熟的方法