一个实现自动求和/合并单元格/排序的DataGrid

原创 2004年09月25日 20:02:00
以前在asp很难实现代码重用,asp.net很好的解决了这个问题,以下是我写的DataGrid,继承DataGrid,加进了升降序/全并单元格/自动求和功能,原理很简单,但很好的实现的代码重用.
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
namespace SunService
{
/// <summary>
/// Summary description for DataGrid.
/// </summary>
[DefaultProperty("Text"),
ToolboxData("<{0}:DataGrid runat=server></{0}:DataGrid>")]
public class DataGrid : System.Web.UI.WebControls.DataGrid
{
private string text;
private SqlDataAdapter adp;
private DataSet ds;
private DataView view;
private string[] arritem;
[Bindable(true),
Category("Appearance"),
DefaultValue("")]
public string Text
{
get
{
return text;
}

set
{
text = value;
}
}
/// <summary>
/// protect SortDirection 排序方向
/// </summary>

public string SortDirection
{
get
{
if(ViewState["SortDirection"]==null)
{
return null;
}
else
{
if(ViewState["SortDirection"].ToString()=="")
{
return null;
}
else
{
return ViewState["SortDirection"].ToString();
}
}
}
set
{
ViewState["SortDirection"]=value;
}
}
/// <summary>
/// protect SortField 排序字段
/// </summary>
public string SortField
{
get
{
if(ViewState["SortField"]==null)
{
return null;
}
else
{
if(ViewState["SortField"].ToString()=="")
{
return null;
}
else
{
return ViewState["SortField"].ToString();
}
}
}
set
{
ViewState["SortField"]=value;
}
}
/// <summary>
/// sql 查询字串
/// </summary>
public string selectCommandText
{
get
{
if(ViewState["selectCommandText"]==null)
{
return null;
}
else
{
if(ViewState["selectCommandText"].ToString()=="")
{
return null;
}
else
{

return ViewState["selectCommandText"].ToString();
}
}
}
set
{
ViewState["selectCommandText"]=value;
}
}
/// <summary>
/// 连接字串
/// </summary>
public string selectConnectionString
{
get
{
if(ViewState["selectConnectionString"]==null)
{
return null;
}
else
{
return ViewState["selectConnectionString"].ToString();
}
}
set
{
ViewState["selectConnectionString"]=value;
}
}
public DataTable Bindtable;
public DataGrid()
{
this.Init+=new System.EventHandler(this.DataGrid_Init);
}
private void DataGrid_Init(object sender,EventArgs e)
{

this.Load+= new System.EventHandler(this.DataGrid_Load);
this.SortCommand+=new System.Web.UI.WebControls.DataGridSortCommandEventHandler(this.DataGrid_SortCommand);
this.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(this.DataGrid_ItemDataBound);

}
private void DataGrid_Load(object sender,EventArgs e)
{
this.HorizontalAlign=HorizontalAlign.Center;
this.AllowSorting=true;
arritem=new string[256];
ds=new DataSet();


}

/// <summary>
/// GRID绑定
/// </summary>
/// <param name="selectCommandText">查询字串</param>
/// <param name="selectConnectionString">连接字串</param>
public void BindGrid(string selectCommandText,string selectConnectionString)
{
this.selectCommandText=selectCommandText;
this.selectConnectionString=selectConnectionString;
BindGrid();

}
/// <summary>
/// grid绑定
/// </summary>
/// <param name="selectCommandText">查询字串</param>
/// <param name="cn">连接对象</param>
public void BindGrid(string selectCommandText,SqlConnection cn)
{
this.selectCommandText=selectCommandText;
this.selectConnectionString=cn.ConnectionString;
BindGrid();
}
/// <summary>
/// grid绑定,必须先设置 selectCommmandText 及SelectConnectionString 属性
/// </summary>
public void BindGrid()
{
if(this.selectCommandText!=null&&this.selectConnectionString!=null)
{
adp=new SqlDataAdapter(this.selectCommandText,this.selectConnectionString);
adp.Fill(ds,"temp");
view=ds.Tables["temp"].DefaultView;

if(this.SortField!=null)
{
view.Sort=this.SortField+" "+this.SortDirection;
int sortfieldindex=0;
for( int i=0;i<ds.Tables["temp"].Columns.Count;i++)
{
if(ds.Tables["temp"].Columns[i].ColumnName==this.SortField)
{
sortfieldindex=i;
break;
}
}
string SortDirectionImg="▲";
if(this.SortDirection==" DESC")
{
SortDirectionImg="▼";

}
if(this.SortField!=this.DataKeyField)
{
ds.Tables["temp"].Columns[sortfieldindex].ColumnName+=SortDirectionImg;
}

}
Bindtable=ds.Tables["temp"];
DataRow row=Bindtable.NewRow();
row[0]="总计:";
for(int i=1;i<Bindtable.Columns.Count;i++)
{
Type t=Bindtable.Columns[i].DataType;
if(t==typeof(Decimal)||t==typeof(Double)||t==typeof(Int16)||t==typeof(Int32)||t==typeof(Int64)||t==typeof(UInt16)||t==typeof(UInt32)||t==typeof(Int64))
{
row[i]=0;
foreach( DataRow r in Bindtable.Rows)
{
try
{
row[i]=double.Parse(row[i].ToString())+double.Parse(r[i].ToString());
}
catch(Exception et)
{

}

}
}
}
Bindtable.Rows.Add(row);

this.DataSource=view;
this.DataBind();

}
else
{

}
}
private void DataGrid_SortCommand(object source, System.Web.UI.WebControls.DataGridSortCommandEventArgs e)
{

if( this.SortDirection==" DESC")
{
this.SortDirection=" ASC";
}
else
{
this.SortDirection=" DESC";
}

this.SortField=e.SortExpression;
this.SortField=this.SortField.Replace("▲","");
this.SortField=this.SortField.Replace("▼","");

BindGrid();
}


private void DataGrid_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
try
{
string txt="";
for(int i=0;i<e.Item.Cells.Count;i++)
{
// e.Item.Cells[i].Wrap=false;
txt=e.Item.Cells[i].Text.Trim();

if(myClass.IsDouble(txt))
{
e.Item.Cells[i].HorizontalAlign=HorizontalAlign.Right;
}
else
{
if(txt==arritem[i]&&txt!=""&&txt!=null)
{
e.Item.Cells[i].Text="";
}
else
{
arritem[i]=txt;
}
}
}
}
catch(Exception et)
{

}

}


}
}


调用简单:
把组件拖到页面中 ,假设ID为 DataGrid1:
调用:DataGrid1.BindGrid(string selectCommandText,string selectConnectionString)
这样省了建 conntion DataAdapter DataSet再绑定的时间.
大家还可把显示时间显示格式/数字显示格式等加进ItemDataBound事件中,还有自定义分页功能等.

DataGrid自动求和、合并单元格、排序

using System;using System.Web.UI;using System.Web.UI.WebControls;using System.ComponentModel;using S...
  • asthlon
  • asthlon
  • 2004年12月22日 10:10
  • 1277

DataGrid自动求和、合并单元格、排序

  以前在asp很难实现代码重用,asp.net很好的解决了这个问题,以下是我写的DataGrid,继承DataGrid,加进了升降序/全并单元格/自动求和功能,原理很简单,但很好的实现的代码重用.u...
  • colayungnew
  • colayungnew
  • 2004年10月14日 15:22
  • 718

DataGrid自动求和、合并单元格、排序

DataGrid自动求和、合并单元格、排序 以前在asp很难实现代码重用,asp.net很好的解决了这个问题,以下是我写的DataGrid,继承DataGrid,加进了升降序/全并单元格/自动求和功能...
  • zydmango
  • zydmango
  • 2006年09月20日 20:53
  • 505

EasyUI-datagrid-自动合并单元格(转)

EasyUI-datagrid-自动合并单元格(转) Posted on 2014-08-21 17:25 shenyixin 阅读(5749) 评论(1) 编辑 收藏 1.目标  ...
  • dong281055686xin
  • dong281055686xin
  • 2016年04月14日 10:32
  • 1991

一个实现自动求和、合并单元格、排序的DataGrid(转)

 一个实现自动求和、合并单元格、排序的DataGrid作者:雪地青松  以前在asp很难实现代码重用,asp.net很好的解决了这个问题,以下是我写的DataGrid,继承DataGrid,加进了升降...
  • nopole
  • nopole
  • 2008年07月23日 09:24
  • 411

Easyui datagrid 动态合并单元格实现

最近在页面开发商遇到了一个新需求,要求在datagrid中实现同名单元格纵向合并效果...
  • u012760435
  • u012760435
  • 2017年01月09日 17:40
  • 526

JQuery EasyUI DataGrid动态合并单元格

/** * EasyUI DataGrid根据字段动态合并单元格 * @param fldList 要合并table的id * @param fldLi...
  • china165
  • china165
  • 2014年12月04日 08:34
  • 1292

easyui表格datagrid自动排序

easyui表格提供了分页和排序的功能,只要通
  • shi_hong_fei_hei
  • shi_hong_fei_hei
  • 2014年06月19日 11:00
  • 2489

asp.net GridView、DataGrid行单元格自动合并

GridView原理和DataGrid一样 this.dg_list.DataSource = run.GetDataSet(strSQL.ToString());this.dg_l...
  • qq285679784
  • qq285679784
  • 2015年05月27日 19:53
  • 1111

easyui datagrid合并单元格

因为客户蛋疼的需求,要求页面展示如此,第一次遇到合并单元格, 在网上百度了一下,看到很多大神的代码,自己模仿着写了一个简单的但又能满足蛋疼的需求,话不多说,上代码 在处理数据之前,必须得保证要合并...
  • angela_77
  • angela_77
  • 2016年10月26日 16:54
  • 2987
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个实现自动求和/合并单元格/排序的DataGrid
举报原因:
原因补充:

(最多只允许输入30个字)