我使用的是Telerik RadGrid,并在某些列上设置了自定义过滤器。 作为自定义过滤器(它只是一个文本框)的一部分,我还有一个按钮,当单击时我想清除该特定列的过滤器值。
我有按钮工作,并将特定列的过滤器设置为空字符串,然后重新绑定网格,但这不会删除过滤器值。
似乎只修改grid.MasterTableView.FilterExpression实际上会影响过滤器但是如何从FilterExpression中删除一个列的过滤器值?
<telerik:RadTextBox ID="RdTxtC" EmptyMessage="Search" runat="server" EmptyMessageStyle-Font-Italic="true"
CssClass="padtop4" HoveredStyle-Font-Italic="true" ClientEvents-OnKeyPress="filterC"
InputType="Text" Width="80%">
</telerik:RadTextBox>
<asp:Button ID="ibtnClearFilterTown" ClientIDMode="Static" runat="server" CssClass="clearFilterButton" OnClick="ibtnClearFilterTown_Click"/>
在代码隐藏中:
protected void ibtnClearFilterTown_Click(object sender, EventArgs e)
{
RgClientList.MasterTableView.GetColumnSafe("TownCity").CurrentFilterValue = String.Empty;
RgClientList.Rebind();
}
删除单个列的过滤器似乎是一个相当简单的要求,所以我认为我必须遗漏一些明显的东西 - 任何帮助都会受到赞赏....
答案 0 :(得分:4)
继续尝试,而不是代码中的内容:
protected void ibtnClearFilterTown_Click(object sender, EventArgs e)
{
RgClientList.MasterTableView.GetColumnSafe("TownCity").CurrentFilterFunction = GridKnownFunction.NoFilter;
RgClientList.MasterTableView.GetColumnSafe("TownCity").CurrentFilterValue = String.Empty;
RgClientList.Rebind();
}
此外,根据this question asked on SO,您可能需要在Radgrid上更改以下属性:
EnableLinqExpressions="False"
编辑1:(将其按下按钮)
我理解这看起来很像你想做的事情,但我检查了Telerik的文档,并没有看到简单的方法从MasterTableView.FilterExpression中删除一个过滤字符串。这主要是由于每个列将其过滤器存储为文本的方式,而不是进入最终过滤器字符串的值。
我将引导您完成以下步骤:
然后它将网格的过滤器设置为新值,然后重新绑定。
String MasterFilterExp = "";
var tempCollection = (from String sFilt in RadGrid1.MasterTableView.FilterExpression.Split(new string[] {"AND"},StringSplitOptions.None)
where sFilt.Contains("[columnnameoffilteryouwantremoved]") != true
select sFilt).ToArray();
MasterFilterExp = string.Join(" AND ", tempCollection);
foreach (GridColumn column in RadGrid1.MasterTableView.Columns)
{
if (column.UniqueName == "columnnameoffilteryouwantremoved")
{
column.CurrentFilterFunction = GridKnownFunction.NoFilter;
column.CurrentFilterValue = String.Empty;
}
}
RadGrid1.MasterTableView.FilterExpression = MasterFilterExp;
RadGrid1.Rebind();
它可以简化,但如果您有任何疑问,请告诉我。我测试了它,并且能够从网格中删除列的过滤器并重新绑定以显示更新的信息。
答案 1 :(得分:0)
为什么不尝试使用Javascript:
function FilterMenuShowing(sender, eventArgs)
{
if (eventArgs.get_column().get_uniqueName() == "IsPostable")
{
var menu = eventArgs.get_menu();
var items = menu._itemData;
var i = 0;
while (i < items.length)
{
var item = menu._findItemByValue(items[i].value);
if (item != null)
item._element.style.display="none";
i++;
}
}
}
您可以查看详细信息here