通过ComboBox过滤RadGrid

时间:2014-10-10 22:36:44

标签: c# asp.net combobox telerik radgrid

我的问题是,当我尝试点击Radgrid中的组合框时,它没有做任何事情。

 <telerik:RadGrid ID="RadGrid" runat="server" DataSourceID="TestReleaseInformationSource" ShowStatusBar="true"
            OnItemCommand="RadGridItemCommand" OnPreRender="RadGrid_PreRender" AllowAutomaticUpdates="true" EnableLinqExpressions="false"
            AllowAutomaticDeletes="true" AllowPaging="true" AutoGenerateColumns="false" AllowFilteringByColumn="true">
            <MasterTableView DataKeyNames="PrimaryKey">
                <Columns>
                    <telerik:GridBoundColumn AllowFiltering="true" UniqueName="TeacherLastName" DataField="TeacherLastName" HeaderText="Last Name">
                        <FilterTemplate>
                            <telerik:RadComboBox ID="radComboBoxLastName" DataSourceID="TeacherLastNameDDL" DataTextField="TeacherLastName" DataValueField="TeacherLastName"
                                AppendDataBoundItems="true" SelectedValue='<%# ((GridItem)Container).OwnerTableView.GetColumn("TeacherLastName").CurrentFilterValue %>'
                                runat="server" OnClientSelectedIndexChanged="TeacherLastNameChanged">
                                <Items>
                                    <telerik:RadComboBoxItem Text="All" Selected="true" />
                                </Items>
                            </telerik:RadComboBox>
                            <telerik:RadScriptBlock ID="RadScriptBlock1" runat="server">
                                <script type="text/javascript">
                                    function TeacherLastNameChanged(sender, args)
                                    {
                                        var tableView = $find("<%# ((GridItem)Container).OwnerTableView.ClientID %>");
                                        tableView.filter("TeacherLastName", args.get_item().get_value(), "EqualTo");
                                    }
                                </script>
                            </telerik:RadScriptBlock>
                        </FilterTemplate>
                    </telerik:GridBoundColumn>

关于网格的预渲染

    protected void RadGrid_PreRender(object sender, EventArgs e)
    {
        if (RadGrid.EditItems.Count > 0)
        {
            GridNestedViewItem item = (GridNestedViewItem)RadGrid.MasterTableView.GetItems(GridItemType.NestedView)[Convert.ToInt32(RadGrid.EditIndexes[0])];
            item.Visible = false;
        }

        if (RadGrid.MasterTableView.FilterExpression != string.Empty)
        {
            RefreshCombos();
        }
    }

    protected void RefreshCombos()
    {
        TestReleaseInformationSource.SelectCommand = TestReleaseInformationSource.SelectCommand + " WHERE " + RadGrid.MasterTableView.FilterExpression.ToString();

        RadGrid.MasterTableView.Rebind();
    }

我已经盯着这几个小时了,无法弄清问题是什么。任何想法将不胜感激。如有必要,会发布更多代码。

我找到的解决方案是将组合框的RenderMode属性设置为native。我仍然想要一个不同的解决方法。

1 个答案:

答案 0 :(得分:0)

尝试使JS函数独一无二:http://www.telerik.com/support/kb/details/using-dynamic-unique-names-for-javascript-functions 我认为所有这些都互相覆盖,所以只有最后一个是活动的,所以只执行。另外,查找JS错误。

另外,尝试从客户端调用过滤,如http://www.telerik.com/help/aspnet-ajax/grid-client-side-binding-adding-sort-filter-expressions.html所示。 masterTableView对象最好通过主网格对象的get_masterTableView()方法获得。