导航

目   录:Farseer.net轻量级开源框架 目录

上一篇:Farseer.net轻量级开源框架 中级篇: BasePage、BaseController、BaseHandler、BaseMasterPage、BaseControls基类使用

下一篇:Farseer.net轻量级开源框架 中级篇: 常用工具

  在使用框架的时候,都需要引用扩展方法的命名空间:using FS.Extend;

         /// <summary>
/// 将值转换成类型对像的值(此方法作为公共的调用,只支持单值转换)
/// </summary>
/// <param name="objValue">要转换的值</param>
/// <param name="objType">要转换的值类型</param>
/// <param name="defType">转换失败时,代替的默认值类型</param>
/// <returns></returns>
private static object ConvertType(object objValue, Type objType, Type defType)

  作者在写代码的时候,最常用的到的方法就属ConvertType了。可以将任意的基本类型转到新的基本类型中。比如将"1"转成1 ,将"true"转成true等等。太实用了。

         /// <summary>
/// 结果为True时,输出参数
/// </summary>
/// <param name="b">判断源结果</param>
/// <param name="t">输出值</param>
public static T IsTrue<T>(this bool b, T t)

  当为true时,返回传入的结果。可以代替: true ? "xxxx" : "" 这种尴尬的写法。

         /// <summary>
/// 获取中文
/// </summary>
/// <param name="b"></param>
/// <param name="strTrue">为True时的中文:是</param>
/// <param name="strFalse">为False时的中文:否</param>
/// <returns></returns>
public static string GetName(this bool b, string strTrue = "是", string strFalse = "否")

  拿到bool结果时,有时候我们希望是:true ? "对" : "错" 这种方式。

         /// <summary>
/// 对DataTable排序
/// </summary>
/// <param name="dt">要排序的表</param>
/// <param name="sort">要排序的字段</param>
public static DataTable Sort(this DataTable dt, string sort = "ID DESC")

  对DataTable经常操作的朋友,对它的排序是不是很麻烦呢?这里用到的是克隆后的结果哦。

         /// <summary>
/// 对DataTable分页
/// </summary>
/// <param name="dt">源表</param>
/// <param name="pageSize">每页显示的记录数</param>
/// <param name="pageIndex">页码</param>
/// <returns></returns>
public static DataTable Split(this DataTable dt, int pageSize = , int pageIndex = )

  对DataTable分页,也是很实用的。

         /// <summary>
/// DataTable转换为实体类
/// </summary>
/// <param name="dt">源DataTable</param>
/// <typeparam name="T">实体类</typeparam>
public static List<TResult> ToList<TResult>(this DataTable dt) where TResult : ModelInfo, new()

  将DataTable转化成List<实体>。

         /// <summary>
/// 获取枚举中文
/// </summary>
/// <param name="eum">枚举值</param>
public static string GetName(this Enum eum)

  得到枚举值的中文显示

         /// <summary>
/// 获取枚举列表
/// </summary>
public static Dictionary<int, string> ToDictionary(this Type enumType)

  可以将枚举的所有元素转成字典

        /// <summary>
/// IDataReader转换为实体类
/// </summary>
/// <param name="reader">源IDataReader</param>
/// <typeparam name="T">实体类</typeparam>
public static List<T> ToList<T>(this IDataReader reader) where T : ModelInfo /// <summary>
/// 数据填充
/// </summary>
/// <param name="reader">源IDataReader</param>
/// <typeparam name="T">实体类</typeparam>
public static T ToInfo<T>(this IDataReader reader) where T : ModelInfo, new()

  将IDataReader转成List<实体>或者 单个实体

         /// <summary>
/// 数据分页
/// </summary>
/// <typeparam name="TSource">实体</typeparam>
/// <param name="source">源对像</param>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">每页大小</param>
public static IQueryable<TSource> Split<TSource>(this IQueryable<TSource> source, int pageSize = , int pageIndex = )

  对List进行分页

         /// <summary>
/// 将List转换成字符串
/// </summary>
/// <param name="lst">要拼接的LIST</param>
/// <param name="sign">分隔符</param>
public static string ToString(this IEnumerable lst, string sign = ",")

  对List<T>按照指定分隔符拼接成字符串。如"1,2,3,4"

         /// <summary>
/// 判断是否存在记录
/// </summary>
/// <param name="IDs">条件,等同于:o=> IDs.Contains(o.ID) 的操作</param>
public static bool IsHaving<TInfo>(this IEnumerable<TInfo> lst, List<int> IDs) where TInfo : ModelInfo, new()

  根据条件判断是否存在

         /// <summary>
/// 字段选择器
/// </summary>
/// <param name="select">字段选择器</param>
/// <param name="IDs">条件,等同于:o=> IDs.Contains(o.ID) 的操作</param>
/// <param name="lst">列表</param>
public static List<T> ToSelectList<TInfo, T>(this IEnumerable<TInfo> lst, Func<TInfo, T> select)

  投影出指定元素列表。

         /// <summary>
/// 将集合类转换成DataTable
/// </summary>
/// <param name="list">集合</param>
/// <returns></returns>
public static DataTable ToDataTable(this IList list)

  List<实体> 转 DataTable

         /// <summary>
/// 将任何数组转换成用符号连接的字符串
/// </summary>
/// <param name="obj">任何对像</param>
/// <param name="func">传入要在转换过程中要执行的方法</param>
/// <param name="sign">分隔符</param>
/// <typeparam name="T">基本对像</typeparam>
public static string ToString<T>(this T[] obj, string sign = ",", Func<T, string> func = null)

  对数组T[]按照指定分隔符拼接成字符串。如"1,2,3,4"

         /// <summary>
/// 直接返回分隔后的元素项
/// </summary>
/// <param name="arr">要分隔的字符串</param>
/// <param name="tag">分隔的标识</param>
/// <param name="index">元素下标</param>
/// <returns></returns>
public static string Split(this string arr, string tag, int index)

  根据指定字符串进行分隔,相当于"xxxx;xxx;".Split(";")[index]

         /// <summary>
/// 指定清除标签的内容
/// </summary>
/// <param name="str">内容</param>
/// <param name="tag">标签</param>
/// <param name="options">选项</param>
public static string ClearString(this string str, string tag, RegexOptions options = RegexOptions.None)

  使用正则清除符合规则的字符串。

         /// <summary>
/// 将字符串转换成List型
/// </summary>
/// <param name="str">要转换的字符串</param>
/// <param name="splitString">分隔符为NullOrEmpty时,则直接拆份为Char</param>
/// <param name="defValue">默认值(单项转换失败时,默认值为NullOrEmpty时,则不添加,否则替换为默认值)</param>
/// <typeparam name="T">基本类型</typeparam>
public static List<T> ToList<T>(this string str, T defValue, string splitString = ",")

  将字符串以指定的分隔符,转成List 比如 "1,2,3,4,5" 以 , 分隔转成List<int>

         /// <summary>
/// 删除指定最后的字符串(直到找到为止)
/// </summary>
/// <param name="str">要转换的字符串</param>
/// <param name="strChar">要删除的字符串</param>
public static string DelLastOf(this string str, string strChar)

  删除末尾的字符串。

         /// <summary>
/// 比较两者是否相等,不考虑大小写,两边空格
/// </summary>
/// <param name="str">对比一</param>
/// <param name="str2">对比二</param>
/// <returns></returns>
public static bool IsEquals(this string str, string str2)

  比较两者是否相等,不考虑大小写,两边空格

         /// <summary>
/// 是否不为Null或者Empty
/// </summary>
/// <param name="str">要判断的字符串</param>
public static bool IsHaving(this string str) /// <summary>
/// 是否为Null或者Empty
/// </summary>
/// <param name="str">要判断的字符串</param>
public static bool IsNullOrEmpty(this string str)

  判断值为空的情况

         /// <summary>
/// 对比开头字符是否一致
/// </summary>
/// <param name="str">原字符串</param>
/// <param name="value">要对比的字符串</param>
/// <returns></returns>
public static bool IsStartsWith(this string str, string value) /// <summary>
/// 对比开头字符是否一致
/// </summary>
/// <param name="str">原字符串</param>
/// <param name="value">要对比的字符串</param>
/// <returns></returns>
public static bool IsEndsWith(this string str, string value)

  不区别大小写

         /// <summary>
/// 分隔字符串
/// </summary>
/// <param name="str">字符串</param>
/// <param name="splitString">分隔符号</param>
/// <returns></returns>
public static string[] Split(this string str, string splitString = ",")

  支持字符串分隔符

         /// <summary>
/// 当NullOrEmpty,用新的字符串代替,否则用原来的。
/// </summary>
/// <param name="str">要检测的值</param>
/// <param name="newString">要替换的新字符串</param>
public static string WhileNullOrEmpty(this string str, string newString)

  当NullOrEmpty,用新的字符串代替,否则用原来的。 很多时候,有些值为null,但我们希望它为NULL时默认给与值。非NULL时,则不理会。

         /// <summary>
/// 数字格式化,将转换成1000,10
/// </summary>
public static string Format(this int number, bool isHaveTag = true, int len = )

  转换成金钱格式。

导航

目   录:Farseer.net轻量级开源框架 目录

上一篇:Farseer.net轻量级开源框架 中级篇: BasePage、BaseController、BaseHandler、BaseMasterPage、BaseControls基类使用

下一篇:Farseer.net轻量级开源框架 中级篇: 常用工具

广告时间

QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net

Farseer.Net是一款ORM框架 + 常用工具 + 扩展集合。

Farseer 意为:先知、预言家 通常在某些场合时,提供计谋、策略。也希望该框架能给大家提供最大化的便捷。

ORM:其英文全称是:Object(对象) Relational(关系) Mapping(映射)

Farseer.Net的目标是:快速上手、快速开发、简单方便。

 new User { ID = , Name = "张三" }.Insert()

Farseer.net轻量级开源框架 中级篇:常用的扩展方法的更多相关文章

  1. Farseer.net轻量级开源框架 中级篇:Cookies、Session、Request

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(Mapping) 下一篇:Farseer.net轻量级开源框架 中级篇 ...

  2. Farseer.net轻量级开源框架 中级篇:UrlRewriter 地址重写

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: Cookies.Session.Request 下一篇:Farseer.net轻量 ...

  3. Farseer.net轻量级开源框架 中级篇:BasePage、BaseController、BaseHandler、BaseMasterPage、BaseControls基类使用

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: UrlRewriter 地址重写 下一篇:Farseer.net轻量级开源框架 中 ...

  4. Farseer.net轻量级开源框架 中级篇:探究ORM(Mapping)

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: SQL执行报告 下一篇:Farseer.net轻量级开源框架 中级篇: Cooki ...

  5. Farseer.net轻量级开源框架 中级篇:SQL执行报告

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 下一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(M ...

  6. Farseer.net轻量级开源框架 中级篇:事务的使用

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: Where条件的终极使用 下一篇:Farseer.net轻量级开源框架 中级篇: ...

  7. Farseer.net轻量级开源框架 中级篇:执行SQL语句

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 事务的使用 下一篇:Farseer.net轻量级开源框架 中级篇: DbFacto ...

  8. Farseer.net轻量级开源框架 中级篇:DbFactory数据工厂

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 执行SQL语句 下一篇:Farseer.net轻量级开源框架 中级篇: 数据绑定 ...

  9. Farseer.net轻量级开源框架 中级篇:数据绑定

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: DbFactory数据工厂 下一篇:Farseer.net轻量级开源框架 中级篇: ...

随机推荐

  1. ul、li中的DIV垂直居中

    当li高度可动态改变时,li中的DIV始终保持垂直居中. 由于高度不固定,不能用margin或者padding解决. 最头疼的是vertical-align: middle;也莫名其妙的失效了. 最终 ...

  2. MongoDB数据库的初识

    1,MongoDB是基于分布式文件存储的数据库,有c++语言编写,旨在为WEB应用提供可扩展的高效性能数据存储解决方案. MongoDB是一个介于关系型数据库和非关系数据库之间的产品,是非关系数据库当 ...

  3. 列表和元组的基本操作,for遍历,range

    1,list(增删改查):列表可以装大量数据,不限制数据的类型(int,str,bool, list,tuple,dict,set),表示方法用[  ],list和sttr有区别,list可以直接在原 ...

  4. npm学习笔记

    NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种: 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用户从NPM服务器下载并 ...

  5. 求两个list的交集和并集

    两个list的并集,只需去除重复元素即可: 将两个list放入同一个set中即可: 两个list的交集: 1将其中一个list放入set, 2循环另一个list,每次向set塞值, 3判断set的总数 ...

  6. 删除oracle数据库用户的dba权限(当出现同一用户DBA可以登录,normal不能登录)“无法对SYS拥有的对象创建触发器”

    系统报错:“无法对SYS拥有的对象创建触发器”,搞不懂是什么原因了,到底这触发器要用什么用户才能建立啊? ORA-04089: 无法对 SYS 拥有的对象创建触发器 第一种方式: 首先,用sys用户a ...

  7. HubbleDotNet开源全文搜索数据库项目--技术详解

    HubbleDotNet 简介 HubbleDotNet 和 Lucene.net 性能对比测试 HubbleDotNet 和 Lucene.Net 匹配相关度的比较 HubbleDotNet 软件架 ...

  8. BZOJ3732:Network(LCT与最小生成树)

    给你N个点的无向图 ( <= N <= ,),记为:…N. 图中有M条边 ( <= M <= ,) ,第j条边的长度为: d_j ( < = d_j < = ,,, ...

  9. Extjs 4 MVC中全局配置文件

    Extjs 4 Config和Mixins http://kldn.iteye.com/blog/1386622 http://www.fengfly.com/html/JavaScript/ExtJ ...

  10. mybatis基础学习5-一对多和多对多(简写)

    1:建实体类 建mysql表