.NET开发

本类阅读TOP10

·NHibernate快速指南(翻译)
·vs.net 2005中文版下载地址收藏
·【小技巧】一个判断session是否过期的小技巧
·VB/ASP 调用 SQL Server 的存储过程
·?dos下编译.net程序找不到csc.exe文件
·通过Web Services上传和下载文件
·学习笔记(补)《.NET框架程序设计(修订版)》--目录
·VB.NET实现DirectDraw9 (2) 动画
·VB.NET实现DirectDraw9 (1) 托管的DDraw
·建站框架规范书之——文件命名

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
DataGrid 中双向排序的一种办法

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

在.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";
    }
   }
  }




相关文章

相关软件