C#中反射和扩展方法如何运用
发布时间 - 2026-01-11 01:02:33 点击率:次前段时间做了一个练手的小项目,名叫Book_Bar,用来卖书的,采用的是三层架构,也就是Models,IDAL,DAL,BLL 和 Web , 在DAL层中各个类中有一个方法比较常用,那就是RowToClass ,顾名思义,也就是将DataTable 中的数据封装到Models 中。结果导致在DAL各个类中写了很多类似的方法,后来就直接把它抽取出来做成了DataTable和DataRow的扩展方法,下面是代码:
using System;
using System.Collections.Generic;
using System.Data;
using System.Reflection;
namespace DAL
{
/// <summary>
/// 用于给 DataTable和 DataRow扩展方法
/// </summary>
public static class TableExtensionMethod
{
/// <summary>
/// 功能:
/// 给DataTable扩展了一个方法,能够将DataTable中的行转变为对应的class对象,并封装到List集合中;
/// </summary>
/// <typeparam name="T">需要转变成为的class类型</typeparam>
/// <param name="table">传入的DataTable对象</param>
/// <returns>返回一个封装了对应class的List集合</returns>
public static List<T> TableToClass<T>(this DataTable table)
{
Type type = typeof(T);
PropertyInfo[] propArr = type.GetProperties();//获取所有属性
List<T> list = new List<T>();
DataRowCollection rows = table.Rows;
int len = rows[0].ItemArray.Length;//获取第一行的列数,即class的属性个数
for (int i = 0; i < rows.Count; i++)
{
T t = (T)Activator.CreateInstance(type);
for (int j = 0; j < len; j++)//这里之所以不使用propArr.Length,是因为有些Models的属性在数据表中不存在对应的列
{
propArr[j].SetValue(t, rows[i][j]);
}
list.Add(t);
t = default(T);
}
return list;
}
/// <summary>
/// 功能:
/// DataRow的扩展方法;
/// 能够将DataRow对象封装到泛型对象中
/// </summary>
/// <typeparam name="T">需要转换成为的class类型</typeparam>
/// <param name="row">被转换的行</param>
/// <returns>封装了行数据的class对象</returns>
public static T RowToClass<T>(this DataRow row)
{
//Type type = Assembly.Load(classFullName).GetType();
Type type = typeof(T);
T t = (T)Activator.CreateInstance(type);
PropertyInfo[] propArr = type.GetProperties();
int len = row.ItemArray.Length;
for (int i = 0; i < len; i++)
{
propArr[i].SetValue(t, row[i]);
}
return t;
}
/// <summary>
/// 功能:
/// DataRowCollection的扩展方法;
/// 能够将DataRowCollection对象封装到泛型List集合中
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="rows"></param>
/// <returns></returns>
public static List<T> RowToClass<T>(this DataRow row, DataRow[] rowArr)
{
Type type = typeof(T);
PropertyInfo[] propArr = type.GetProperties();
int len = rowArr[0].ItemArray.Length;//获取数据表第一行的列数,即属性个数
List<T> list = new List<T>();
for (int i = 0; i < rowArr.Length; i++)
{
T t = (T)Activator.CreateInstance(type);
for (int j = 0; j < len; j++)
{
propArr[j].SetValue(t, rowArr[i][j]);
}
list.Add(t);
t = default(T);
}
return list;
}
}
}
上面用到了泛型,反射,扩展方法。
之前在使用这行代码时出了点小问题:
propArr[i].SetValue(t, row[i]);
报了一个类型转换异常,断点调试之后发现是因为 Models 中的属性的排列和数据表的列的顺序不一样导致的,参照数据表中字段的顺序修改过来就好,还有一点就是在循环对属性进行赋值时,我选用的是数据表中列的个数,而不是属性的个数,(也就是代码中这里之所以不使用propArr.Length,是因为有些Models的属性在数据表中不存在对应的列
)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# C#
# 反射
# 扩展方法
# 详解C#扩展方法原理及其使用
# C#中的扩展方法详解
# 基于C# MBG 扩展方法类库的使用详解
# C# Winform使用扩展方法实现自定义富文本框(RichTextBox)字体颜色
# C#特性 扩展方法
# C# 扩展方法详解
# 是因为
# 的是
# 装了
# 中不
# 类中
# 成了
# 出了
# 就好
# 把它
# 写了
# 顾名思义
# 来做
# 转变为
# 前段时间
# 报了
# 大家多多
# 这行
# 有一个
# 象中
# 而不是
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
制作企业网站建设方案,怎样建设一个公司网站?
如何在IIS7上新建站点并设置安全权限?
C++时间戳转换成日期时间的步骤和示例代码
详解vue.js组件化开发实践
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
nodejs redis 发布订阅机制封装实现方法及实例代码
利用vue写todolist单页应用
如何快速搭建二级域名独立网站?
php打包exe后无法访问网络共享_共享权限设置方法【教程】
QQ浏览器网页版登录入口 个人中心在线进入
Python高阶函数应用_函数作为参数说明【指导】
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
Laravel如何处理CORS跨域请求?(配置示例)
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
如何快速登录WAP自助建站平台?
Thinkphp 中 distinct 的用法解析
如何在万网ECS上快速搭建专属网站?
如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体
HTML 中动态设置元素 name 属性的正确语法详解
Laravel用户密码怎么加密_Laravel Hash门面使用教程
javascript如何操作浏览器历史记录_怎样实现无刷新导航
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
利用 Google AI 进行 YouTube 视频 SEO 描述优化
详解Android——蓝牙技术 带你实现终端间数据传输
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
如何在IIS中配置站点IP、端口及主机头?
Android实现代码画虚线边框背景效果
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
Java类加载基本过程详细介绍
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
Laravel如何创建自定义Artisan命令?(代码示例)
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
微信小程序 require机制详解及实例代码
jQuery中的100个技巧汇总
如何用PHP快速搭建CMS系统?
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
如何快速搭建FTP站点实现文件共享?

