《学习笔记》WPF中根據DataTable和實體類反射出具有動態通知的ObservableCollection集合對象
應用場景
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; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义