前言
最近在給大家寫一套開源的.net core權限管理框架。現在已經寫到前台UI + 后台動態查詢的部分。
發現需要動態orderby但是網上沒有現成的例子
二話不說上代碼
建議namespace
System.Linq.Dynamic
主體代碼
/// <summary> /// 排序 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="query"></param> /// <param name="Field"></param> /// <param name="orderby"></param> /// <returns></returns> public static IQueryable<T> OrderBy<T>(this IQueryable<T> query, string Field, string orderby = "orderb") { if (!string.IsNullOrEmpty(Field)) { ParameterExpression p = Expression.Parameter(typeof(T)); Expression key = Expression.Property(p, Field); var propInfo = GetPropertyInfo(typeof(T), Field); var expr = GetOrderExpression(typeof(T), propInfo); if (!("desc" == orderby)) { var method = typeof(Queryable).GetMethods().FirstOrDefault(m => m.Name == "OrderBy" && m.GetParameters().Length == 2); var genericMethod = method.MakeGenericMethod(typeof(T), propInfo.PropertyType); return (IQueryable<T>)genericMethod.Invoke(null, new object[] { query, expr }); } else { var method = typeof(Queryable).GetMethods().FirstOrDefault(m => m.Name == "OrderByDescending" && m.GetParameters().Length == 2); var genericMethod = method.MakeGenericMethod(typeof(T), propInfo.PropertyType); return (IQueryable<T>)genericMethod.Invoke(null, new object[] { query, expr }); } } return query; } /// <summary> /// 獲取反射 /// </summary> /// <param name="objType"></param> /// <param name="name"></param> /// <returns></returns> private static PropertyInfo GetPropertyInfo(Type objType, string name) { var properties = objType.GetProperties(); var matchedProperty = properties.FirstOrDefault(p => p.Name == name); if (matchedProperty == null) throw new ArgumentException("name"); return matchedProperty; } /// <summary> /// 獲取生成表達式 /// </summary> /// <param name="objType"></param> /// <param name="pi"></param> /// <returns></returns> private static LambdaExpression GetOrderExpression(Type objType, PropertyInfo pi) { var paramExpr = Expression.Parameter(objType); var propAccess = Expression.PropertyOrField(paramExpr, pi.Name); var expr = Expression.Lambda(propAccess, paramExpr); return expr; }
寫在最后
如果您覺着我的文章對您有用麻煩各位大佬點個贊點個關注
然后呢 剛剛創建了一個.net core的群歡迎大家進入:
點擊鏈接加入群聊【.Net Core研究團】:https://jq.qq.com/?_wv=1027&k=5IEolkJ
然后集資創建一個網絡社區。歡迎各位一起集資。