webdn
 
  首页     免费截图     VIP会员区     广告Banner     技术文档     网站模板  
网站截图,网站每日新 !
网页模板

首页 >> WebDN 文档 >> 网络编程 >> ASP.net 技术资料 >> Page 17 >> DataGrid 中一种双向排序的办法

 

DataGrid 中一种双向排序的办法

【摘 要】在.Net 中 DataGrid 虽然有排序的功能,但并不支持双向的排序。

在.Net 中 DataGrid 虽然有排序的功能,但并不支持双向的排序。用到了,看了些相关的帖子,自己尝试了一种方法,竟然也行得通,呵呵

  主要是用DataGrid.Attributes 存了一个参数,同时在onSortCommand中修改了DataGridColumn的SortExpression. 代码如下:

private void BindData()
  {
   DataTable dt = .......;
   if(dt != null)
   {
    DataView dv = dt.DefaultView;
    if(DataGrid1.Attributes["SortBy"] != null)
    {
     dv.Sort = DataGrid1.Attributes["SortBy"];
    }

    DataGrid1.DataSource = dv;
    DataGrid1.DataBind();
   }
  }

private void DataGridSort(object source, System.Web.UI.WebControls.DataGridSortCommandEventArgs e)
  {
   DataGrid1.Attributes["SortBy"] = sortstr;
   this.BindData();

   //找到排序的列,并修改把它的排序属性

   DataGridColumn clm = null;

   for(int i=0;i<DataGrid1.Columns.Count;i++)
   {
    if(DataGrid1.Columns[i].SortExpression == e.SortExpression )
    {
     clm = DataGrid1.Columns[i];
     break;
    }
   }

   if(clm == null) return;
  
   if(e.SortExpression.ToLower().IndexOf("desc") > 0)
   {
    clm.SortExpression = e.SortExpression.ToLower().Replace("desc","asc");
   }
   else
   {
    if(e.SortExpression.ToLower().IndexOf("asc") > 0)
    {
     clm.SortExpression = e.SortExpression.ToLower().Replace("asc","desc");
    }
    else
    {
     clm.SortExpression = e.SortExpression.ToLower() + " desc";
    }
   }
  }



电话咨询:010-60520722 QQ咨询:3792656   |   583696287   |   66733350 关于WebDN  |  站点地图  |  联系我们  |  支付方式  |  友情链接
© 2004-2008 WebDN.com 版权所有. 沪ICP备05040479号