DataGrid的几个小技巧

原创 2004年10月26日 19:37:00

作者:网际浪子专栏(曾用名littlehb)  http://blog.csdn.net/littlehb/

方法一:使用模版列

我们在绑定好数据的DataGrid增加一个模版列,在列中放置一个按钮
<asp:TemplateColumn>
<ItemTemplate>
<asp:Button id="btnDelete" runat="server" Text="删除"></asp:Button>
</ItemTemplate>
</asp:TemplateColumn>
然后我们在DataGrid的ItemDataBound中添加以下代码
switch(e.Item.ItemType)
{
case(ListItemType.Item):
case(ListItemType.AlternatingItem):
{
Button btn=(Button)e.Item.FindControl("btnDelete");
btn.Attributes.Add("OnClick","return window.confirm('fs')");
break;
}
}
DataGrid在绑定数据的时候将触发此事件,而且每行触发一次.我们可以通过e.Item获得行,而通过e.Item.ItemType获得行类型.

方法二:使用按钮列

我们在绑定好数据的DataGrid增加一个删除按钮列
<asp:ButtonColumn Text="删除" CommandName="Delete"></asp:ButtonColumn>
然后我们在DataGrid的ItemDataBound中添加以下代码
switch(e.Item.ItemType)
{
case(ListItemType.Item):
case(ListItemType.AlternatingItem):
{
LinkButton btn=(LinkButton)e.Item.Cells[4].Controls[0];
btn.Attributes.Add("OnClick","return window.confirm('fs')");
break;
}
}
可以看到我们这里获得控件引用的方法有所不同,使用了e.Item.Cells[4].Controls[0],而没有使用e.Item.FindControl("btnDelete"),因为我


们现在使用的是按钮列,不能对按钮列的按钮设置ID属性,而FindControl是通过ID来查找控件(当然我们也可以把前面的代码用


e.Item.Cells[4].Controls[0]的代码来替换.).

 

添加序号列

绑定好一个DataGrid
switch(e.Item.ItemType)
{
case(ListItemType.Item):
case(ListItemType.AlternatingItem):
{
DataGridItem row=(DataGridItem)e.Item;
TableCell cell=new TableCell();
cell.Controls.Add(new LiteralControl((e.Item.ItemIndex+1).ToString()));
row.Cells.AddAt(0,cell);
break;
}
case(ListItemType.Header):
{
DataGridItem row=(DataGridItem)e.Item;
TableCell cell=new TableCell();
cell.Controls.Add(new LiteralControl("序号"));
row.Cells.AddAt(0,cell);
break;
}
}
这里我们用到了e.Item.ItemIndex,获取来自 DataGrid 控件的 Items 集合的 DataGridItem 对象的索引.


产生两行的标题行

绑定好一个DataGrid,设置允许分页,设置页导航为上下型,一会我们将强制把上面的页导航更换成标题行.这里我想讲一下DataGrid的行构成
最上面Pager,用来放置分页导航,然后是表头Header,接着是Item和AlternatingItem项目和交替项目(当然还有SelectedItem选中项和EditItem


编辑项等),然后是Footer表脚,最下面还有一个Pager.因为Pager行是系统自动产生的,所以在ItemDataBound事件中不能捕获此行,这里我使用了


ItemCreated事件,添加代码如下
switch(e.Item.ItemType)
{
case(ListItemType.Pager):
{
if(first)
{
DataGridItem row=(DataGridItem)e.Item;
row.Cells.Clear();
TableCell cell0=new TableCell();
cell0.Controls.Add(new LiteralControl("ID"));
TableCell cell1=new TableCell();
cell1.ColumnSpan=2;
cell1.Controls.Add(new LiteralControl("FullName"));
row.Cells.Add(cell0);
row.Cells.Add(cell1);
}
first=!first;
break;
}
}
这里的First用来判断是上面的Pager还是下面的Pager.

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/21aspnet/article/details/153262

DataGrid的几个小技巧!

方法一:使用模版列我们在绑定好数据的DataGrid增加一个模版列,在列中放置一个按钮然后我们在DataGrid的ItemDataBound中添加以下代码switch(e.Item.ItemType)...
  • littlehb
  • littlehb
  • 2004-10-25 13:47:00
  • 765

DataGrid的几个小技巧

DataGrid的几个小技巧 删除时给出提示方法一:使用模版列我们在绑定好数据的DataGrid增加一个模版列,在列中放置一个按钮asp:TemplateColumn>ItemTemplate>asp...
  • chenhongwu
  • chenhongwu
  • 2006-10-26 21:43:00
  • 285

DataGrid的几个小技巧

删除时给出提示方法一:使用模版列我们在绑定好数据的DataGrid增加一个模版列,在列中放置一个按钮然后我们在DataGrid的ItemDataBound中添加以下代码switch(e.Item.It...
  • fhgok
  • fhgok
  • 2005-04-09 00:09:00
  • 340

DataGrid导出EXCEL的几个方法(WebControl)

  • 2009年06月25日 18:03
  • 6KB
  • 下载

日常生活小技巧 -- 玩转 PDF

一、PDF 翻译芯片手册、用户手册等多是PDF文件,多是英文的。下面介绍一下,如何将英文的 pdf 翻译为中文的。百度搜索到的翻译网页大多是需要付费的。那么免费的应该用什么呢?推荐,谷歌翻译:http...
  • qq_29350001
  • qq_29350001
  • 2017-12-11 12:18:06
  • 352

Windows XP的几个小技巧

  • 2010年08月27日 13:06
  • 5KB
  • 下载

批量改名六大神技

批量改名六大神技shell实例1:改名指令rename的用法如下:[root@ChangerLee 批量改名]# touch file_{1..10}[root@ChangerLee 批量改名]# l...
  • ChangerJJLee
  • ChangerJJLee
  • 2016-08-11 08:04:04
  • 368

数据绑定的几个页及小技巧.rar

  • 2008年10月14日 11:30
  • 53KB
  • 下载

几个ASP.NET小技巧.txt

  • 2013年07月11日 12:40
  • 3KB
  • 下载

NetLogo中文学习教程及ppt教程

  • 2013年06月09日 00:18
  • 2.87MB
  • 下载
收藏助手
不良信息举报
您举报文章:DataGrid的几个小技巧
举报原因:
原因补充:

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