4

我正在尝试向我的 RadGrid 添加自定义过滤器。我有一个列,vendNum,我想允许用户使用逗号分隔的列表过滤多个 vendNum。基本上,我想要与 SQL 中的“in”语句相同的功能(其中 vendNum 在 (X,Y,Z) 中)。

我按照这个网站上的教程,想出了以下代码来放置在我的 RadGrid1_ItemCommand 事件中。

 protected void RadGrid1_ItemCommand(object source, GridCommandEventArgs e)
        {
            if (e.CommandName == RadGrid.FilterCommandName)
            {
                Pair filterPair = (Pair)e.CommandArgument;
    
                switch (filterPair.Second.ToString())
                {               
                    case "vendNum":
                        TextBox tbPattern = (e.Item as GridFilteringItem)["vendNum"].Controls[0] as TextBox;
                        if (tbPattern.Text.Contains(","))
                        {
                            string[] values = tbPattern.Text.Split(',');
                            if (values.Length >= 2)
                            {
                                e.Canceled = true;
                                StringBuilder newFilter = new StringBuilder();
                                for (int i = 0; i < values.Length; i++)
                                {
                                    if (i == values.Length - 1)
                                        newFilter.Append("[vendNum] = " + values[i]);
                                    else
                                        newFilter.Append("[vendNum] = " + values[i] + " OR ");
                                }
                                if (RadGrid1.MasterTableView.FilterExpression == "")
                                    RadGrid1.MasterTableView.FilterExpression = newFilter.ToString();
                                else
                                    RadGrid1.MasterTableView.FilterExpression = "((" + RadGrid1.MasterTableView.FilterExpression + ") AND (" + newFilter.ToString() + "))";
                                RadGrid1.Rebind();
                            }
                        }
                        break;
                    default:
                        break;
                }
            }
        }

但是,当我尝试使用逗号分隔列表进行过滤时,这样做会不断给我一个错误“预期表达式”。我仍然能够过滤单个vendNum。我的FilterExpression确实按预期出来了。RadGrid1.Rebind()代码在语句上失败。以前有没有人处理过这个问题?任何帮助是极大的赞赏。

谢谢,

亚伦

忘记编辑这个

几周前我解决了这个问题......我不得不在 RadGrid 下将“EnableLinqExpressions”属性设置为 false。

4

1 回答 1

8

我认为这是在某个地方解决这个问题的方法。

尝试添加:RadGrid1.EnableLinqExpressions = false;

于 2010-04-08T01:24:41.450 回答