扩展GridView控件(11) - 合并指定列的相邻且内容相同的单元格
来源:互联网 发布:赛诺数据中国手机9月 编辑:程序博客网 时间:2024/06/05 07:07
[源码下载]
扩展GridView控件(11) - 合并指定列的相邻且内容相同的单元格
作者:webabcd
介绍
扩展GridView控件:
合并指定列的相邻且内容相同的单元格
使用方法(设置属性):
MergeCells - 需要合并单元格的列的索引(用逗号“,”分隔)
关键代码
实现“合并指定列的相邻且内容相同的单元格”功能的代码
using System;
using System.Collections.Generic;
using System.Text;
using System.Web.UI.WebControls;
using System.Web.UI;
namespace YYControls.Helper
{
/**//// <summary>
/// SmartGridView的Helper
/// </summary>
public class SmartGridView
{
/**//// <summary>
/// 合并指定列的相邻且内容相同的单元格
/// </summary>
/// <param name="gv">GridView</param>
/// <param name="columnIndices">需要合并单元格的列的索引(用逗号“,”分隔)</param>
public static void MergeCells(GridView gv, int[] columnIndices)
{
// 指定的列中需要设置RowSpan的单元格的行索引
int[] aryInt = new int[columnIndices.Length];
// 是否重新指定aryInt的相关元素的值
// aryInt中的元素与aryBln中的元素一一对应
bool[] aryBln = new bool[columnIndices.Length];
// aryInt初值均为0
for (int i = 0; i < aryInt.Length; i++)
{
aryInt[i] = 0;
}
// aryBln初值均为true
for (int i = 0; i < aryBln.Length; i++)
{
aryBln[i] = true;
}
for (int i = 1; i < gv.Rows.Count; i++)
{
// 本行和上一行均为DataControlRowType.DataRow
if (gv.Rows[i].RowType == DataControlRowType.DataRow && gv.Rows[i - 1].RowType == DataControlRowType.DataRow)
{
// 遍历指定的列索引
for (int j = 0; j < columnIndices.Length; j++)
{
// 列索引超出范围则不处理
if (columnIndices[j] < 0 || columnIndices[j] > gv.Columns.Count - 1) continue;
// 相邻单元格的内容相同
if (gv.Rows[i].Cells[columnIndices[j]].Text == gv.Rows[i - 1].Cells[columnIndices[j]].Text)
{
if (aryBln[j])
aryInt[j] = i - 1;
if (gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan == 0)
gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan = 1;
gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan++;
gv.Rows[i].Cells[columnIndices[j]].Visible = false;
aryBln[j] = false;
}
else
{
aryBln[j] = true;
}
}
}
}
}
}
}
上面的MergeCells(GridView gv, int[] columnIndices)方法用于实现“合并指定列的相邻且内容相同的单元格”,第一个参数是GridView,第二个参数是需要合并单元格的列的索引(用逗号“,”分隔)。
为GridView新增一个属性
using System;
using System.Collections.Generic;
using System.Text;
using System.ComponentModel;
namespace YYControls
{
/**//// <summary>
/// SmartGridView类的属性部分
/// </summary>
public partial class SmartGridView
{
private string _mergeCells;
/**//// <summary>
/// 需要合并单元格的列的索引(用逗号“,”分隔)
/// </summary>
[
Browsable(true),
Description("需要合并单元格的列的索引(用逗号“,”分隔)"),
Category("扩展")
]
public virtual string MergeCells
{
get { return _mergeCells; }
set { _mergeCells = value; }
}
}
}
继承YYControls.SmartGridViewFunction.ExtendFunction抽象类,重写其Execute()方法
using System;
using System.Collections.Generic;
using System.Text;
using System.Web.UI.WebControls;
namespace YYControls.SmartGridViewFunction
{
/**//// <summary>
/// 扩展功能:合并指定列的相邻且内容相同的单元格
/// </summary>
public class MergeCellsFunction : ExtendFunction
{
/**//// <summary>
/// 构造函数
/// </summary>
public MergeCellsFunction()
: base()
{
}
/**//// <summary>
/// 构造函数
/// </summary>
/// <param name="sgv">SmartGridView对象</param>
public MergeCellsFunction(SmartGridView sgv)
: base(sgv)
{
}
/**//// <summary>
/// 扩展功能的实现
/// </summary>
protected override void Execute()
{
this._sgv.DataBound += new EventHandler(_sgv_DataBound);
}
/**//// <summary>
/// SmartGridView的DataBound事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void _sgv_DataBound(object sender, EventArgs e)
{
string[] ary = this._sgv.MergeCells.Split(',');
int[] columnIndices = new int[ary.Length];
// 将字符串数组转为整型数组
for (int i = 0; i < columnIndices.Length; i++)
{
int j;
if (!Int32.TryParse(ary[i], out j))
{
// 转整型失败则赋值为-1,“合并指定列的相邻且内容相同的单元格”则不会处理
j = -1;
}
columnIndices[i] = j;
}
YYControls.Helper.SmartGridView.MergeCells(this._sgv, columnIndices);
}
}
}
- 扩展GridView控件(11) - 合并指定列的相邻且内容相同的单元格
- 扩展GridView控件(11) - 合并指定列的相邻且内容相同的单元格
- jquery 合并相邻且内容相同单元格
- gridview合并同一列相同内容的单元格
- jquery 合并相同内容的单元格,根据某列可以指定合并后面的任意列
- 用Javascript合并指定表格相同文本的相邻单元格
- jquery合并单元格(表格相邻列内容相同合并)
- excel将某列内容相同的相邻单元格合并
- 使用VBA实现Excel合并相同内容的相邻单元格
- DataGridView 合并同一列中值相同的相邻单元格 合并单元格
- GridView、DataGrid 表头合并、表体合并[合并相邻行相同数据的单元格
- GridView 相同列内容合并单元格 (任意列)
- 合并内容相同的单元格
- GridView相同内容合并单元格
- 用jQuery合并表格中左侧表头同列相同文本的相邻单元格
- 用jQuery合并表格中左侧表头同列相同文本的相邻单元格
- Gridview中合并单元格,某字段的内容相同时如何只显示一个,屏蔽相同列或行的内容
- GridView中数据相同的单元格合并
- Access保留字&变量名列表,建表时应避免使用这些词汇和符号。
- 扩展GridView控件(8) - 导出数据源的数据为Excel、Word或Text
- 扩展GridView控件(9) - 给数据行增加右键菜单
- Ie和firefox的Js区别
- 扩展GridView控件(10) - 自定义分页样式
- 扩展GridView控件(11) - 合并指定列的相邻且内容相同的单元格
- JUnit使用小记
- 扩展GridView控件(索引) - 增加多个常用功能
- JavaScript execCommand大全
- dUP v2.17 Beta 23 汉化版 by tracky
- 理解Session State模式+ASP.NET SESSION丢失FAQ
- 扩展GridView控件(0) - 基本架构、增加事件和要点汇总
- fck 的写入删除特定text的js ff ie7测试通过
- 操作iframe中的DOM元素