.NET开发

本类阅读TOP10

·vs.net 2005中文版下载地址收藏
·NHibernate快速指南(翻译)
·【小技巧】一个判断session是否过期的小技巧
·通过Web Services上传和下载文件
·?dos下编译.net程序找不到csc.exe文件
·VB/ASP 调用 SQL Server 的存储过程
·学习笔记(补)《.NET框架程序设计(修订版)》--目录
·对比.NET PetShop和Duwamish来探讨Ado.NET的数据库编程模式
·Autodesk官方最新的.NET教程(一)(vb.net版)
·Duwamish深入剖析-结构篇

分类导航
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";
    }
   }
  }




相关文章

相关软件




月光软件程序下载编程文档电脑教程网站设计网址导航网络文学游戏天地幽默笑话生活休闲写作范文安妮宝贝
电脑技术编程开发网络专区谈天说地情感世界游戏元素分类游戏热门游戏体育运动手机专区业余爱好影视沙龙
音乐天地数码广场教育园地科学大观古今纵横谈股论金人文艺术医学保健动漫图酷二手专区地方风情各行各业

月光软件站·版权所有