1

GridViewC# でmy をデータバインドするクラスに取り組んでいます...

ページャーが機能するようにしましたが、ソートを機能させる方法がわかりません...これまでのところ、私のコードは次のようになります。

public static class Binder
{
public class gridView {
    public static void Bind(GridView grid, IList source, bool pager, bool sorting) {
        grid.DataSource = source;
        if (pager) {
            grid.PageIndexChanging += new GridViewPageEventHandler(PageIndexChanging);
        }
        if (sorting) {
            grid.Sorting += new GridViewSortEventHandler(Sorting);
        }
        grid.DataBind();
    }

    public static void PageIndexChanging(object sender, GridViewPageEventArgs e) {
        if (sender != null) {
            GridView GridView1 = sender as GridView;
            GridView1.PageIndex = e.NewPageIndex;
            GridView1.DataBind();
        }
    }
    public static void Sorting(object sender, GridViewSortEventArgs e) {
        if (sender != null) {
            GridView GridView1 = sender as GridView;
            //What to do?
            GridView1.DataBind();
        }
    }
}
}

そして、私は次のようにグリッドビューをバインドします:Binder.gridView.Bind(MyGridView, MyDataSource, true, true);

しかし、並べ替えを機能させる方法にちょっと迷っていますか?

4

2 に答える 2

0

バインディング、ページング、およびソートのためのこのコード........

 protected void RadgvData_SortCommand(object sender, GridSortCommandEventArgs e)
        {
            GridTableView tableView = e.Item.OwnerTableView;
            e.Canceled = true;
            GridSortExpression expression = new GridSortExpression();
            expression.FieldName = e.SortExpression;
            if (tableView.SortExpressions.Count == 0 || tableView.SortExpressions[0].FieldName != e.SortExpression)
            {
                expression.SortOrder = GridSortOrder.Descending;
            }
            else if (tableView.SortExpressions[0].SortOrder == GridSortOrder.Descending)
            {
                expression.SortOrder = GridSortOrder.Ascending;
            }
            else if (tableView.SortExpressions[0].SortOrder == GridSortOrder.Ascending)
            {
                expression.SortOrder = GridSortOrder.Descending;
            }

            tableView.SortExpressions.AddSortExpression(expression);
            RadgvData.Rebind();

        }

        protected void RadgvData_NeedDataSource(object sender, GridNeedDataSourceEventArgs e)
        {
            try
            {
                DataTable dtData = objCutTypeBAL.getCutTypeDetail(string.Empty);
                if (dtData.Rows.Count > 0)
                {
                    RadgvData.DataSource = dtData;
                }
                else
                {
                    RadgvData.DataSource = String.Empty;
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        protected void RadgvData_ItemDataBound(object sender, GridItemEventArgs e)
        {
            if (e.Item is GridPagerItem)
            {
                RadgvData.PagerStyle.AlwaysVisible = true;
            }
            if (e.Item is GridDataItem && e.Item.OwnerTableView.DataMember != "ChildCutType")
            {
                GridDataItem dataitem = (GridDataItem)e.Item;

                ImageButton imgDel = (ImageButton)dataitem["Delete"].Controls[0];
                string strCutType;
                strCutType = dataitem.GetDataKeyValue("CutType").ToString();
                DataTable dtData = objCutTypeBAL.getCutTypeDetail(strCutType);
                if (dtData.Rows.Count > 0)
                {
                    imgDel.Visible = false;
                }
            }
        }

        protected void RadgvData_PageIndexChanged(object sender, GridPageChangedEventArgs e)
        {
            RadgvData.CurrentPageIndex = e.NewPageIndex;
            popGrid();
        }
于 2013-04-16T09:38:09.003 に答える
0

aspx で並べ替えを有効にする必要があります - AllowSorting="True"

<asp:GridView ID="grid" runat="server" DataKeyNames="id" AutoGenerateColumns="False"
                AllowPaging="True" AllowSorting="True" PageSize="25" CellPadding="4" BorderStyle="None"
                OnRowDataBound="gvProfileSearch_RowDataBound" Width="100%" Translate="true">

IList には OrderBy-Function を使用できます

IList<T> tmp = new IList<T>();
tmp.OrderByDescending...
tmp.OrderBy...
于 2013-03-14T12:01:59.463 に答える