[C#]合并单元格(行、列)
2016-07-20 16:15
344 查看
説明:控件ID指的是页面上面的GridView控件的ID名称或者是DataGrid控件的ID名称;
控件类型写GridView或者DataGrid(根据页面控件属于那种就写那种)。
如有疑问请留言。。。。。。。
/// <summary>
/// 合并单元格(合并某一行的所有列)
/// </summary>
/// <param name="id">控件的ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">需要合并的行</param>
public static void GroupRow(string id,string type, int rows)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[0];
for (int i = 1; i < GridView1.Rows[rows].Cells.Count; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[0];
for (int i = 1; i < DataGrid1.Items[rows].Cells.Count; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
}
}
/// <summary>
/// 合并单元格(合并一行中的几列)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">行</param>
/// <param name="sCol">开始列</param>
/// <param name="eCol">结束列</param>
public static void GroupRow(string id, string type, int rows, int sCol, int eCol)
{
Control contr = new Control();
TableCell oldTc = null;
switch (type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[sCol];
for (int i = 1; i < eCol - sCol; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[sCol];
for (int i = 1; i < eCol - sCol; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
}
}
/// <summary>
/// 合并单元格(合并某一列所有行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">需要合并的列</param>
public static void GroupCol(string id, string type, int cols)
{
Control contr = new Control();
if (type == "GridView")
{
GridView GridView1 = (GridView)contr.FindControl(id);
if (GridView1.Rows.Count < 1 || cols > GridView1.Rows[0].Cells.Count - 1)
{
return;
}
TableCell oldTc = GridView1.Rows[0].Cells[cols];
for (int i = 1; i < GridView1.Rows.Count; i++)
{
TableCell tc = GridView1.Rows[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
else
{
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
if (DataGrid1.Items.Count < 1 || cols > DataGrid1.Items[0].Cells.Count - 1)
{
return;
}
TableCell oldTc = DataGrid1.Items[0].Cells[cols];
for (int i = 1; i < DataGrid1.Items.Count; i++)
{
TableCell tc = DataGrid1.Items[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
}
/// <summary>
/// 合并单元格(合并某一列中的某些行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">列</param>
/// <param name="sRow">开始行</param>
/// <param name="eRow">结束列</param>
public static void GroupCol(string id, string type, int cols, int sRow, int eRow)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
if (GridView1.Rows.Count < 1 || cols > GridView1.Columns.Count - 1)
{
return;
}
oldTc = GridView1.Rows[sRow].Cells[cols];
for (int i = 1; i < eRow - sRow; i++)
{
TableCell tc = GridView1.Rows[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
if (DataGrid1.Items.Count < 1 || cols > DataGrid1.Columns.Count - 1)
{
return;
}
oldTc = DataGrid1.Items[sRow].Cells[cols];
for (int i = 1; i < eRow - sRow; i++)
{
TableCell tc = DataGrid1.Items[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
af28
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
default:
break;
}
}
控件类型写GridView或者DataGrid(根据页面控件属于那种就写那种)。
如有疑问请留言。。。。。。。
/// <summary>
/// 合并单元格(合并某一行的所有列)
/// </summary>
/// <param name="id">控件的ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">需要合并的行</param>
public static void GroupRow(string id,string type, int rows)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[0];
for (int i = 1; i < GridView1.Rows[rows].Cells.Count; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[0];
for (int i = 1; i < DataGrid1.Items[rows].Cells.Count; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
}
}
/// <summary>
/// 合并单元格(合并一行中的几列)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">行</param>
/// <param name="sCol">开始列</param>
/// <param name="eCol">结束列</param>
public static void GroupRow(string id, string type, int rows, int sCol, int eCol)
{
Control contr = new Control();
TableCell oldTc = null;
switch (type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[sCol];
for (int i = 1; i < eCol - sCol; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[sCol];
for (int i = 1; i < eCol - sCol; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == 0)
{
oldTc.ColumnSpan = 1;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
}
}
/// <summary>
/// 合并单元格(合并某一列所有行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">需要合并的列</param>
public static void GroupCol(string id, string type, int cols)
{
Control contr = new Control();
if (type == "GridView")
{
GridView GridView1 = (GridView)contr.FindControl(id);
if (GridView1.Rows.Count < 1 || cols > GridView1.Rows[0].Cells.Count - 1)
{
return;
}
TableCell oldTc = GridView1.Rows[0].Cells[cols];
for (int i = 1; i < GridView1.Rows.Count; i++)
{
TableCell tc = GridView1.Rows[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
else
{
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
if (DataGrid1.Items.Count < 1 || cols > DataGrid1.Items[0].Cells.Count - 1)
{
return;
}
TableCell oldTc = DataGrid1.Items[0].Cells[cols];
for (int i = 1; i < DataGrid1.Items.Count; i++)
{
TableCell tc = DataGrid1.Items[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
}
/// <summary>
/// 合并单元格(合并某一列中的某些行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">列</param>
/// <param name="sRow">开始行</param>
/// <param name="eRow">结束列</param>
public static void GroupCol(string id, string type, int cols, int sRow, int eRow)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
if (GridView1.Rows.Count < 1 || cols > GridView1.Columns.Count - 1)
{
return;
}
oldTc = GridView1.Rows[sRow].Cells[cols];
for (int i = 1; i < eRow - sRow; i++)
{
TableCell tc = GridView1.Rows[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
if (DataGrid1.Items.Count < 1 || cols > DataGrid1.Columns.Count - 1)
{
return;
}
oldTc = DataGrid1.Items[sRow].Cells[cols];
for (int i = 1; i < eRow - sRow; i++)
{
TableCell tc = DataGrid1.Items[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == 0)
{
af28
oldTc.RowSpan = 1;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
default:
break;
}
}
相关文章推荐
- 分享微信开发Html5轻游戏中的几个坑
- c#调用COM组件
- 星外ASP.Net的安全设置相关说明
- C#实现把指定数据写入串口
- C#动态创建button的方法
- C#中抽象方法与虚拟方法的区别
- c#中虚函数的相关使用方法
- C#实现给图片加水印的方法
- C#使用加边法计算行列式的值
- C#实现多线程的同步方法实例分析
- C#中尾递归的使用、优化及编译器优化
- C#中的delegate委托类型基本学习教程
- C#实现子窗体与父窗体通信方法实例总结
- C#通用邮件发送类分享
- 举例讲解C#中自动实现的属性
- C#中this的用法集锦
- C#数据结构之顺序表(SeqList)实例详解
- C#.NET获取拨号连接的宽带连接方法
- C#异步绑定数据实现方法
- C#实现AddRange为数组添加多个元素的方法