本文共 1443 字,大约阅读时间需要 4 分钟。
在开发ASP.NET Web API或ASP.NET MVC时,我们从数据库得到的数据往往是DataSet或是DataTable。为了能让前端JQuery能方便使用至这些数据,我们需要把这些数据转换为泛型List<T>或是JSON。
Insus.NET有把这个转换功能写成一个扩展方法:方法源代码:public static ListToList (this DataTable dt) { var columnNames = dt.Columns.Cast () .Select(c => c.ColumnName) .ToList(); var properties = typeof(T).GetProperties(); return dt.AsEnumerable().Select(row => { var objT = Activator.CreateInstance (); foreach (var pro in properties) { if (columnNames.Contains(pro.Name)) pro.SetValue(objT, row[pro.Name] == DBNull.Value ? string.Empty : row[pro.Name].ToString(), null); } return objT; }).ToList(); }
把DataTable转换为JSON:
方法源代码:
public static string ToJson(this DataTable table) { List> list = new List >(); foreach (DataRow row in table.Rows) { Dictionary dict = new Dictionary (); foreach (DataColumn col in table.Columns) { dict[col.ColumnName] = row[col]; } list.Add(dict); } return serializer.Serialize(list); }
实例应用,可以从下面这篇可以参考:《》
转载地址:http://evmix.baihongyu.com/