應用場景
MVVM是通過ObservableCollection集合對象來實現數據集動態新增和修改并通知的,現數據庫查詢工具查出來的是DataTable,此時需將DataTable轉ObservableCollection來達到業務需求
/// <summary> /// 根據DataTable和實體類反射出具有動態通知的ObservableCollection集合對象 /// </summary> /// <typeparam name="T">實體類/泛型對象</typeparam> /// <param name="dt">數據列表</param> /// <returns></returns> public static ObservableCollection<T> GetList<T>(DataTable dt) where T : class, new() { try { Type t = typeof(T); PropertyInfo[] propertys = t.GetProperties();//獲取泛型T的字段屬性名稱 ObservableCollection<T> dataList = new ObservableCollection<T>(); string typeName = string.Empty;//創建一個字段名稱用來存儲泛型T反射出來的實體類字段名稱 foreach (DataRow dr in dt.Rows)//遍歷DataTable內容 { T entity = new T();//創建泛型T對象 foreach (PropertyInfo pi in propertys) { typeName = pi.Name;//獲取泛型T中的字段名稱並且賦值 if (dt.Columns.Contains(typeName))//判斷DataRow中列名于泛型字段名相等 { if (!pi.CanWrite) continue; object value = dr[typeName];//取DataRow的值 if (value == DBNull.Value) continue;//判斷值是否為空 if (pi.PropertyType == typeof(string))//判斷泛型字段屬性類型 { if (value is null) value = "";//字段為空就變為空字符串 pi.SetValue(entity, value.ToString(), null);//賦值 } else if (pi.PropertyType == typeof(int) || pi.PropertyType == typeof(int?))//判斷泛型字段屬性類型 { pi.SetValue(entity, int.Parse(value.ToString()), null);//賦值 } else if (pi.PropertyType == typeof(DateTime?) || pi.PropertyType == typeof(DateTime))//判斷泛型字段屬性類型 { pi.SetValue(entity, DateTime.Parse(value.ToString()), null);//賦值 } else if (pi.PropertyType == typeof(float))//判斷泛型字段屬性類型 { pi.SetValue(entity, float.Parse(value.ToString()), null);//賦值 } else if (pi.PropertyType == typeof(double))//判斷泛型字段屬性類型 { pi.SetValue(entity, double.Parse(value.ToString()), null);//賦值 } else { pi.SetValue(entity, value, null);//賦值 } } } dataList.Add(entity);//賦值 } return dataList;//返回結果集 } catch (Exception ex) { throw ex; }