0

我无法gridview使用参数对我进行排序AutoGenerateColumns = false 标题不可点击,因此我无法排序,尽管有参数AllowSort = true

这是我的网格视图:

 <asp:Label ID="lbSortColumn" runat="server" Visible="False"></asp:Label>
            <asp:GridView ID="gvDeslocFinal" runat="server" Height="181px" Width="1042px" OnRowDataBound="gvDeslocFinal_RowDataBound" AutoGenerateColumns="false" AllowSorting="true" OnSorting="gvDeslocFinal_Sorting" OnPageIndexChanging="gvDeslocFinal_PageIndexChanging" OnSorted="gvDeslocFinal_Sorted" AllowPaging="True">

            <Columns>
                ...
            </Columns>
            <EditRowStyle HorizontalAlign="Center" />
            <HeaderStyle VerticalAlign="Middle" HorizontalAlign="Center" Font-Bold="False" Height="30px" />

            <RowStyle HorizontalAlign="Center" VerticalAlign="Middle" Height="20px" />
        </asp:GridView>

这是我的功能:

     protected void gvDeslocFinal_Sorting(object sender, GridViewSortEventArgs e)
        {
            if (gvDeslocFinal.EditIndex >= 0)
                return;

            string[] values = lbSortColumn.Text.Split(' ');
            if (values[0] == e.SortExpression)
            {
                if (values[1] != null && values[1] == "ASC")
                    lbSortColumn.Text = e.SortExpression + " DESC";
                else
                    lbSortColumn.Text = e.SortExpression + " ASC";
            }
            else
            {
                lbSortColumn.Text = e.SortExpression + " ASC";
            }


        }


 protected void gvDeslocFinal_Sorted(object sender, EventArgs e)
        {
            if (gvDeslocFinal.EditIndex >= 0)
                return;
            BindGrid();
        }
4

1 回答 1

0

在您粘贴的代码片段中,您没有显示列定义供我确认,但这可能是您的问题:

如果您设置AutoGenerateColumns=false,那么您必须定义您的列,并且在这些列定义中您必须设置 SortExpression 属性。例如...

<Columns>
    <asp:BoundField HeaderText="Name" DataField="itemName" SortExpression="itemName"/>
    ...
</Columns>
于 2020-07-15T15:18:19.420 回答