用于过滤的动态Lambda表达式 [英] Dynamic Lambda Expression For Filtering

查看:92
本文介绍了用于过滤的动态Lambda表达式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在网页上有3个过滤条件

I have 3 filter conditions on a web page

  1. 按下拉列表源过滤
  2. 按下拉列表过滤类别
  3. 在StartDate文本框和EndDate文本框之间进行过滤

我目前正在从表中获取所有行,并将它们放入数据集中.我现在希望能够根据用户可能输入的上述过滤器的任意组合来过滤该数据集.或者,也许用户选择不输入过滤器.

I currently am getting all rows back from the table and putting them in dataset. I want to now be able to filter that dataset based on any combination of the above filters the user may input. Or maybe the user chooses to input no filters.

有人可以帮我使用Lambda表达式进行设置吗?

Can someone help me set this up using lambda expressions?

推荐答案

这是我在自己的代码中用于应用过滤器的模式:

This is the pattern I use in my own code for applying filters:

var data = GetData();

var sourceFilter = SourceDropDown.Value;
if (!string.IsNullOrEmpty(sourceFilter))
    data = data.Where(d => d.Source == sourceFilter);

var categoryFilter = CategoryDropDown.Value;
if (!string.IsNullOrEmpty(categoryFilter))
    data = data.Where(d => d.Category == categoryFilter);

DateTime startDateFilter, endDateFilter;
if (DateTime.TryParse(TxtStartDate.Text, out startDateFilter) &&
    DateTime.TryParse(TxtEndDate.Text, out endDateFilter))
    data = data.Where(d => d.DT >= startDateFilter && d.DT <= endDateFilter);

return data.ToList();

这篇关于用于过滤的动态Lambda表达式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆