asp.net中GridView和DataGrid相同列合并实现代码
更新时间:2021年9月22日 10:18 点击:1938
(一)普通列
/// <summary>
/// Gridview列的合并(普通列,不包含模板列)
/// 注意:1.GridView在绑定的时候进行分组和排序,才能让相同的行放在一起
/// 2.方法应用的时机,应该在Gridview的DataBound事件中使用
/// </summary>
/// <param name="gv">需要合并的GridView对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
public static void UnitCell(GridView gv, int columnIndex)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = gv.Rows[0].Cells[columnIndex].Text.ToString();
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < gv.Rows.Count; i++)
{
if (gv.Rows[i].Cells[columnIndex].Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = gv.Rows[i].Cells[columnIndex].Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}
/// <summary>
/// DataGrid列的合并(普通列,不包含模板列)
/// 注意:1.DataGrid在绑定的时候进行分组和排序,才能让相同的行放在一起
/// 2.方法应用的时机,应该在DataGrid的DataBound事件中使用
/// </summary>
/// <param name="dg">需要合并的DataGrid对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
public static void UnitCell_T(DataGrid dg, int columnIndex)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (dg.Items.Count> 0)
{
lastType = dg.Items[0].Cells[columnIndex].Text.ToString();
dg.Items[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < dg.Items.Count; i++)
{
if (dg.Items[i].Cells[columnIndex].Text == lastType)
{
dg.Items[i].Cells[columnIndex].Visible = false;
dg.Items[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = dg.Items[i].Cells[columnIndex].Text.ToString();
lastCell = i;
dg.Items[i].Cells[columnIndex].RowSpan = 1;
}
}
}
(二)模板列
/// <summary>
/// Gridview列的合并(模板列)
/// </summary>
/// <param name="gv">需要合并的GridView对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
/// <param name="lblName">模板列对象的ID</param>
public static void UnitCell(GridView gv, int columnIndex, string lblName)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = (gv.Rows[0].Cells[columnIndex].FindControl(lblName) as Label).Text;
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < gv.Rows.Count; i++)
{
if ((gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = (gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}
(三)在DataBound事件中调用即可。
在GridView或DataGrid中显示固定宽度的列
默认情况下,Gridview和Datagrid控件依据它们的内容自动调整列大小。要为列指定固定宽度,设置每个Tablecell对象的Width属性并设置Wrap属性为False。下面的例子显示了如何通过使用DataGrid控件去做。
rotected void DataGrid1_ItemCreated(object sender, DataGridItemEventArgs e)
{
ListItemType lit = e.Item.ItemType;
if (lit == ListItemType.Header)
{
for (int i = 0; i < e.Item.Cells.Count; i++)
{
e.Item.Cells[i].Width = Unit.Pixel(50);
e.Item.Cells[i].Wrap = false;
}
}
}
复制代码 代码如下:
/// <summary>
/// Gridview列的合并(普通列,不包含模板列)
/// 注意:1.GridView在绑定的时候进行分组和排序,才能让相同的行放在一起
/// 2.方法应用的时机,应该在Gridview的DataBound事件中使用
/// </summary>
/// <param name="gv">需要合并的GridView对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
public static void UnitCell(GridView gv, int columnIndex)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = gv.Rows[0].Cells[columnIndex].Text.ToString();
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < gv.Rows.Count; i++)
{
if (gv.Rows[i].Cells[columnIndex].Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = gv.Rows[i].Cells[columnIndex].Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}
/// <summary>
/// DataGrid列的合并(普通列,不包含模板列)
/// 注意:1.DataGrid在绑定的时候进行分组和排序,才能让相同的行放在一起
/// 2.方法应用的时机,应该在DataGrid的DataBound事件中使用
/// </summary>
/// <param name="dg">需要合并的DataGrid对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
public static void UnitCell_T(DataGrid dg, int columnIndex)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (dg.Items.Count> 0)
{
lastType = dg.Items[0].Cells[columnIndex].Text.ToString();
dg.Items[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < dg.Items.Count; i++)
{
if (dg.Items[i].Cells[columnIndex].Text == lastType)
{
dg.Items[i].Cells[columnIndex].Visible = false;
dg.Items[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = dg.Items[i].Cells[columnIndex].Text.ToString();
lastCell = i;
dg.Items[i].Cells[columnIndex].RowSpan = 1;
}
}
}
(二)模板列
复制代码 代码如下:
/// <summary>
/// Gridview列的合并(模板列)
/// </summary>
/// <param name="gv">需要合并的GridView对象</param>
/// <param name="columnIndex">所要合并列的索引</param>
/// <param name="lblName">模板列对象的ID</param>
public static void UnitCell(GridView gv, int columnIndex, string lblName)
{
int i = 0; //当前行数
string lastType = string.Empty; //当前判断是否合并行对应列的值
int lastCell = 0; //判断最后一个相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = (gv.Rows[0].Cells[columnIndex].FindControl(lblName) as Label).Text;
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i < gv.Rows.Count; i++)
{
if ((gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = (gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}
(三)在DataBound事件中调用即可。
在GridView或DataGrid中显示固定宽度的列
默认情况下,Gridview和Datagrid控件依据它们的内容自动调整列大小。要为列指定固定宽度,设置每个Tablecell对象的Width属性并设置Wrap属性为False。下面的例子显示了如何通过使用DataGrid控件去做。
复制代码 代码如下:
rotected void DataGrid1_ItemCreated(object sender, DataGridItemEventArgs e)
{
ListItemType lit = e.Item.ItemType;
if (lit == ListItemType.Header)
{
for (int i = 0; i < e.Item.Cells.Count; i++)
{
e.Item.Cells[i].Width = Unit.Pixel(50);
e.Item.Cells[i].Wrap = false;
}
}
}
相关文章
c# WPF中通过双击编辑DataGrid中Cell的示例(附源码)
这篇文章主要介绍了c# WPF中通过双击编辑DataGrid中Cell的示例(附源码),帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下...2021-03-03jQuery EasyUI编辑DataGrid用combobox实现多级联动
本文给大家分享jQuery EasyUI编辑DataGrid用combobox实现多级联动效果的实例代码,代码简单易懂,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧...2016-09-01- 这篇文章主要介绍了C#实现3步手动建DataGridView的方法,实例分析了C#实现手动创建DataGridView的原理与技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了C#中DataGridView动态添加行及添加列的方法,涉及C#中DataGridView针对行与列动态操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
JQuery EasyUI学习教程之datagrid 添加、修改、删除操作
这篇文章主要介绍了JQuery EasyUI datagrid 添加、修改、删除操作的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...2016-07-25如何解决easyui自定义标签 datagrid edit combobox 手动输入保存不上
这篇文章主要介绍了如何解决easyui自定义标签 datagrid edit combobox 手动输入保存不上,需要的朋友可以参考下...2015-12-28C#中datagridview使用tooltip控件显示单元格内容的方法
这篇文章主要介绍了C#中datagridview使用tooltip控件显示单元格内容的方法,实例分析了C#控件的相关使用技巧,需要的朋友可以参考下...2020-06-25- 这篇文章主要介绍了C#中GridView动态添加列的实现方法,涉及C#中GridView的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 下面小编就为大家带来一篇浅析GridView中显示时间日期格式的问题。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2021-09-22
jQuery EasyUI中DataGird动态生成列的方法
EasyUI中使用DataGird显示数据列表中,有时需要根据需要显示不同的列,例如,在权限管理中,不同的用户登录后只能查看自己权限范围内的列表字段,这就需要DataGird动态组合列,下面介绍EasyUI中DataGird动态生成列的方法...2016-04-06- 这篇文章主要介绍了C#中DataGridView常用操作,以实例形式总结了DataGridView绑定下拉列表、设置默认值、判断复选框是否选中等技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 这个例子的功能是c#读取excel文件,大家可以参考使用...2020-06-25
- Gridview的链接和删除点击提示有利于提醒用户确认下操作是否正确,以免造成不必要的损失,感兴趣的朋友可以参考下,希望对你有所帮助...2021-09-22
- 这篇文章主要介绍了c#中datagridview处理非绑定列的方法,实例分析了C#中datagridview的使用技巧,需要的朋友可以参考下...2020-06-25
实现DataGridView控件中CheckBox列的使用实例
最近做WindowsForms程序,使用DataGridView控件时,加了一列做选择用,发现CheckBox不能选中。搜索后,要实现DataGridView的CellContentClick事件,将代码贴一下...2021-09-22- 这篇文章主要介绍了C#中改变DataGridView控件边框颜色的方法,默认的DataGridView边框颜色很丑,本文用编程方法实现修改DataGridView边框颜色,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了C#实现改变DataGrid某一行和单元格颜色的方法,主要涉及DataGrid控件的添加与使用、数据源的绑定、单元格与行的获取等操作。需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了C#中DataGridView的样式设置方法,包括交替行颜色、单元格内容有效性检查、单元格的选择模式等,需要的朋友可以参考下...2020-06-25
在ASP.NET 2.0中操作数据之六十四:GridView批量添加数据
前面介绍了批量更新,批量删除数据,这篇文章主要介绍如何实现批量添加数据,当然为了保证数据的完整性,我们在做这些批量操作的时候,都使用了事务来实现。...2021-09-22.Net语言Smobiler开发利用Gridview控件设计较复杂的表单
这篇文章主要为大家详细介绍了.Net语言Smobiler开发利用Gridview控件设计较复杂的表单,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-22