博客
关于我
List GroupBy真实用法,Reflection(反射)用法,Enum用法,正则,搜索下拉布局
阅读量:796 次
发布时间:2023-02-05

本文共 3057 字,大约阅读时间需要 10 分钟。

编程技巧实用分享

1. GroupBy 运算的实际应用

GroupBy 是 LINQ 中一个非常实用的方法,用于对集合数据进行分组操作。以下是一个实际场景的 GroupBy 使用示例:

var _roomProducts = homesingProducts.GroupBy(t => t.RoomName);RoomedProducts temp = new RoomedProducts();foreach (var item in _roomProducts){    roomNames.Add(item.Key);    temp = new RoomedProducts();    temp.RoomName = item.Key;    temp.Products = new List
(); temp.Products.AddRange(item); roomedProducts.Add(temp);}

这个代码 snippet 展示了如何根据房间名称对产品列表进行分组,并将每个分组的数据存储到 roomedProducts 列表中。


2. 枚举类与反射的结合使用

为了避免在代码中反复出现类似于 order.state == 50order.statedesc == "已付款" 的情况,可以通过枚举类配合反射来实现状态管理。以下是一个枚举类和反射方法的示例:

public enum DesignOrderState{    ///     /// 待付款    ///     [Description("待付款")]    WaitPaying = 30,    ///     /// 已付款    ///     [Description("已付款")]    Paid = 50,    ///     /// 设计中    ///     [Description("设计中")]    Designing = 70,    ///     /// 已交付    ///     [Description("已交付")]    Completed = 90,}public static Dictionary
ReflectFiledsNameByClassName(string className){ Dictionary
result = new Dictionary
(); Type t = Type.GetType(className); PropertyInfo[] properties = t.GetProperties(); string attr = ""; foreach (var item in properties) { foreach (Attribute _attr in Attribute.GetCustomAttributes(item)) { if (_attr.GetType() == typeof(DescriptionAttribute)) { attr = ((DescriptionAttribute)_attr).Description; } } result.Add(item.Name, attr); attr = ""; } return result;}public static Dictionary
ReflectEnumFiledAndValues(Type type){ Dictionary
result = new Dictionary
(); FieldInfo[] properties = type.GetFields(); foreach (var item in properties) { try { result.Add(item.Name, (int)(Enum.Parse(type, item.Name))); } catch (Exception) { // 忽略不能枚举的字段 } } return result;}public static string ReflectFiledsNameByEnumClassName(string className, string filedName){ string result = ""; Type t = Type.GetType(className); FieldInfo[] properties = t.GetFields(); int length = properties.Length; for (int i = 1; i < length; i++) { if (properties[i].Name == filedName) { DescriptionAttribute attr = Attribute.GetCustomAttribute(properties[i], typeof(DescriptionAttribute), false) as DescriptionAttribute; result = attr.Description; break; } } return result;}

这个代码 snippet 展示了如何通过反射获取枚举类的字段名及其对应的描述信息,以及如何从枚举类中获取字段值。


3. 正则表达式的实用技巧

在前端开发中,正则表达式是处理文本验证的重要工具。以下是一些常用的正则表达式示例:

var password = $("#password").val();if (!(/^[\w\d.,\?]{5,15}$/).test(password)){    alert("密码不能输入特殊字符并且长度为5到15");    return;}// 手机号码验证var mobile = $("#mobile").val();if (!(/^1[34578]\d{9}$/.test(mobile))){    alert('手机号码格式错误!');    return;}

这个代码 snippet 包含了两个常用的正则表达式:

  • ^[\w\d.,\?]{5,15}$ 用于验证密码字符,允许字母、数字、特殊字符(如逗号、问号)在 5 到 15 个字符之间。
  • ^1[34578]\d{9}$ 专门用于验证手机号码格式,确保手机号以 1、3、4、7、8 开头,后面跟着 9 位数字。

  • 4. 搜索引擎友好的下拉布局

    以下是一个简单的搜索下拉布局示例,供开发者参考:

    这个下拉框可以用于搜索页面中的内容分类,用户可以根据需要从多个类型中选择。


    以上就是本次编程技巧分享的内容,希望对你有所帮助!如果需要更多实用技巧,欢迎继续关注我的博客。

    转载地址:http://yzufk.baihongyu.com/

    你可能感兴趣的文章
    Mysql学习总结(37)——Mysql Limit 分页查询优化
    查看>>
    Mysql学习总结(38)——21条MySql性能优化经验
    查看>>
    Mysql学习总结(39)——49条MySql语句优化技巧
    查看>>
    Mysql学习总结(3)——MySql语句大全:创建、授权、查询、修改等
    查看>>
    Mysql学习总结(40)——MySql之Select用法汇总
    查看>>
    Mysql学习总结(41)——MySql数据库基本语句再体会
    查看>>
    Mysql学习总结(42)——MySql常用脚本大全
    查看>>
    Mysql学习总结(43)——MySQL主从复制详细配置
    查看>>
    Mysql学习总结(44)——Linux下如何实现mysql数据库每天自动备份定时备份
    查看>>
    Mysql学习总结(45)——Mysql视图和事务
    查看>>
    Mysql学习总结(46)——8种常被忽视的SQL错误用法
    查看>>
    Mysql学习总结(48)——MySql的日志与备份还原
    查看>>
    Mysql学习总结(49)——从开发规范、选型、拆分到减压
    查看>>
    Mysql学习总结(4)——MySql基础知识、存储引擎与常用数据类型
    查看>>
    Mysql学习总结(50)——Oracle,mysql和SQL Server的区别
    查看>>
    Mysql学习总结(51)——Linux主机Mysql数据库自动备份
    查看>>
    Mysql学习总结(52)——最全面的MySQL 索引详解
    查看>>
    Mysql学习总结(53)——使用MySql开发的Java开发者规范
    查看>>
    Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
    查看>>
    Mysql学习总结(55)——MySQL 语句大全再温习
    查看>>