C#中实现DataGrid双向排序
来源:互联网 发布:电脑接收手机短信软件 编辑:程序博客网 时间:2024/05/16 11:58
在.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";
}
}
}
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序
- C#中实现DataGrid双向排序_C#_.Net开发_软件开发_天新网
- C#中实现DataGrid双向排序(转http://www.91d.cn/article/233/Article_19149_1.html)
- DataGrid 中双向排序的一种办法
- DataGrid 中双向排序的一种办法
- DataGrid 中双向排序的一种办法
- DataGrid 双向的排序
- DataGrid双向排序
- DataGrid正反双向排序
- DataGrid的双向排序
- DataGrid双向排序
- 用动态属性和DataView实现DataGrid的双向排序
- 在c#中执行sql语句时传递参数的小经验
- C# Google PageRank .net库 (checksum)
- IDS研究之Bro和snort的比较分析
- 用C#代码编写的SN快速输入工具
- 工作总结
- C#中实现DataGrid双向排序
- GIS教育这盘棋该怎么走?
- 在c#中实现3层架构
- Bro:一个开放源码的高级NIDS系统
- 分享动态生成文字图片解决方案
- 一个调查实例包括全部代码
- 一个SQL更新记录的小技巧
- 分析sql性能
- 捕捉摄相头的数据流