簡體   English   中英

用於根據屬性(字符串列表)過濾數據的表達式

[英]Expression to filter data based on a property which is a list of strings

我有以下代碼:

case FilterQueryType.Contains:
      var parameterExp = Expression.Parameter(type, "type");
      var propertyExp = Expression.Property(parameterExp, filter.PropertyName);
      var containsConstExp = Expression.Constant(filter.MyKeyword);
      MethodInfo method = typeof(string).GetMethod("Contains", new []{typeof(string)});
      var containsMethodExp = Expression.Call(propertyExp, method, containsConstExp);
      var containsLambda = Expression.Lambda<Func<T, bool>>(containsMethodExp, parameterExp);
      items = items.Where(containsLambda);
      break;

只要filter.PropertyName是字符串,此代碼就可以正常工作。 現在,我有一個情況,filter.PropertyName實際上是一個可枚舉的字符串。

有人可以告訴我如何為此創建正確的表達式嗎? (filter.MyKeyword本身將始終是單個值)

 MemberExpression memberExpression = Expression.Property(parameterExp, filter.PropertyName);
 Expression convertExpression = Expression.Convert(memberExpression, typeof(List<string>));
 MethodCallExpression containsExpression = Expression.Call(convertExpression, "Contains", new Type[] { }, constExpr);
 lambda = Expression.Lambda<Func<T, bool>>(containsExpression, parameterExp);
 items = items.Where(lambda);

這個解決方案對我有用

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM