是類型安全!
這是更好地構建的功能列表,將返回的良好性能高於申報,如果有一天你想改變你的列名,將失敗的一個字符串變量:
public class Customer { public string FirstName; public string LastName;}
public class CustomerFilter { public Func<Customer, string> Selector; public string Filter; }
[TestMethod()]
public void DynamicFilterTest()
{
var jonSkeet = new Customer() { FirstName = "Jon", LastName = "Skeet" };
var joelOnSoftware = new Customer() { FirstName = "Joel", LastName = "OnSoftware" };
var customers = new List<Customer>() { jonSkeet, joelOnSoftware };
var jonSkeetFilters = new List<CustomerFilter>() {
new CustomerFilter() { Selector = c => c.LastName, Filter = "Skeet" },
new CustomerFilter() { Selector = c => c.FirstName, Filter = "Jon" }};
var query = customers.AsEnumerable();
foreach (var filter in jonSkeetFilters)
{
query = query.Where(c => filter.Selector.Invoke(c) == filter.Filter);
}
var result = query.ToList();
Assert.AreEqual(1, result.Count);
Assert.AreEqual(jonSkeet, result.Single());
}
然後你就可以輕鬆地重構使用相同的模式爲您的任何邀請:
public class WhereClause<T>
{
private readonly Func<T, string> _selector;
public Func<T, string> Selector { get { return _selector; } }
private readonly string _value;
public string Value { get { return _value; } }
public WhereClause(Func<T, string> selector, string value)
{
this._selector = selector;
this._value = value;
}
/// <summary>
/// Append the where clause to the given query
/// </summary>
/// <param name="query"></param>
/// <returns></returns>
public IEnumerable<T> AppendTo(IEnumerable<T> query)
{
return query.Where(c => this.Selector.Invoke(c) == this.Value);
}
/// <summary>
/// Append the wheres clauses to the given query
/// </summary>
/// <param name="query"></param>
/// <returns></returns>
public static IEnumerable<T> AppendTo(IEnumerable<T> query, IEnumerable<WhereClause<T>> wheres)
{
var filteredQuery = query;
foreach (var where in wheres)
{
filteredQuery = where.AppendTo(filteredQuery);
}
return filteredQuery;
}
}
[TestClass]
public class WhereClauseTests
{
public class Customer { public string FirstName; public string LastName;}
[TestMethod()]
public void WhereClauseTest()
{
var jonSkeet = new Customer() { FirstName = "Jon", LastName = "Skeet" };
var joelOnSoftware = new Customer() { FirstName = "Joel", LastName = "OnSoftware" };
var customers = new List<Customer>() { jonSkeet, joelOnSoftware };
var jonSkeetWheres = new List<WhereClause<Customer>>() {
new WhereClause<Customer>(c => c.LastName, "Skeet"),
new WhereClause<Customer>(c => c.FirstName, "Jon")
};
var query = WhereClause<Customer>.AppendTo(customers, jonSkeetWheres);
var result = query.ToList();
Assert.AreEqual(1, result.Count);
Assert.AreEqual(jonSkeet, result.Single());
}
}
感謝您的答案,非常感謝和工作像一個魅力!有沒有簡單的方法來搜索內嵌(List)屬性?沿着'searchList.Add(「CustomerLikes/CustomerLikedObject.Id」,12345)'? – vzwick
@vzwick從來沒有試圖使用動態LINQ嵌套列表,你應該自己驗證這個功能。但它絕對支持嵌套的對象,如'地址。國家' –