• 《学习笔记》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;
                }
  • 相关阅读:
    积累-T
    HTML:文件标签(四)
    HTML:文件标签(三)
    HTML:文件标签(二)
    队列:最近的请求次数 (Leetcode 933 / Leetcode 232 / 剑指09 / Leetcode 225 / Leetcode 862 )
    HTML:文件标签(一)
    HTML: 介绍 & 规范
    java.sql.SQLException: Access denied for user 'root '@'localhost' (using password: YES)
    JDBC和XML- 学习笔记
    数据库: 商城案例
  • 原文地址:https://www.cnblogs.com/ShyFrog/p/12886247.html
Copyright © 2020-2023  润新知