以下に示すResultSetクラスをとり、ジェネリックになるように修正したいと思います。表示されているように、これはProduct Listのみを受け入れますが、コントローラのコード再利用性のためにList-OneOfMyModels>またはList-T>を使用したいと思います。クラスを受け取り、メソッドがジェネリックリストを受け入れる方法
public class ResultSet
{
public List<Product> GetResult(string search, string sortOrder, int start, int length, List<Product> dtResult, List<string> columnFilters)
{
return FilterResult(search, dtResult, columnFilters).SortBy(sortOrder).Skip(start).Take(length).ToList();
}
public int Count(string search, List<Product> dtResult, List<string> columnFilters)
{
return FilterResult(search, dtResult, columnFilters).Count();
}
private IQueryable<Product> FilterResult(string search, List<Product> dtResult, List<string> columnFilters)
{
IQueryable<Product> results = dtResult.AsQueryable();
results = results.Where(p => (search == null || (p.Name != null && p.Name.ToLower().Contains(search.ToLower()) || p.PublicDisplayNo != null && p.PublicDisplayNo.ToLower().Contains(search.ToLower())))
);
return results;
}
}
そして、私のコントローラで私はそうのようなメソッドを呼び出します。
public JsonResult DataHandler(DTParameters param)
{
try
{
var dtsource = _context.Products.ToList();
List<String> columnSearch = new List<string>();
foreach (var col in param.Columns)
{
columnSearch.Add(col.Search.Value);
}
List<Product> data = new ResultSet().GetResult(param.Search.Value, param.SortOrder, param.Start, param.Length, dtsource, columnSearch);
int count = new ResultSet().Count(param.Search.Value, dtsource, columnSearch);
DTResult<Product> result = new DTResult<Product>
{
draw = param.Draw,
data = data,
recordsFiltered = count,
recordsTotal = count
};
return Json(result);
}
catch (Exception ex)
{
return Json(new { error = ex.Message });
}
}
公開リスト getResult (params ....、List dtResult、param)。ジェネリックList をパラメータとして渡すには、このメソッドをgenericにする必要があります。リストも返すことができます。 –