方法一:使用模版列
我们在绑定好数据的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.
分享到:
相关推荐
datagrid技巧大全,包含多种datagrid的用法和实例。
多功能DataGrid(C#)控件使用技巧!~看看国内比较有影响力的IT培训机构是怎么培训的吧!~看看他们都学了些什么!~从中来找出我们自己的不足!~把资源放出来!~希望和大家一起提高!~欢迎大家下载!~
ASP_NET中DataGrid控件的使用技巧.pdfASP_NET中DataGrid控件的使用技巧.pdfASP_NET中DataGrid控件的使用技巧.pdfASP_NET中DataGrid控件的使用技巧.pdfASP_NET中DataGrid控件的使用技巧.pdf
自己收集整理的几个DataGrid控件使用技巧和大家分享。
DataGrid使用技巧vDataGrid使用技巧DataGrid使用技巧
DataGrid导出EXCEL的几个方法(WebControl)DataGrid导出EXCEL的几个方法(WebControl)DataGrid导出EXCEL的几个方法(WebControl)DataGrid导出EXCEL的几个方法(WebControl)
wpf DataGrid 自定义样式、控件模板 ControlTemplate
用VB实现从Excel表格向Datagrid控件中导入数据!
研究了好久,终于成功在jquery easyui中的datagrid中添加searchbox!
主要是为了简化开发者在使用easyUI datagrid 控件时需要写的内容太多,对页面需要多个datagrid的方便使用方法!
jeasyui-datagrid-datagrid 开发参考
DataGrid一个综合的例子 DataGrid一个综合的例子 DataGrid一个综合的例子 DataGrid一个综合的例子
DataGrid中嵌套DataGrid,修改后也适用DataGrid中嵌套DataList,DataList中嵌套DataList
运用ASP.NET开发Web应用程序过程中,DataGrid是一个非常重要的控件,几乎任何和数据相关的表现都要用到该控件。所以熟练掌握DataGrid控件的应用技巧是每个Web开发人员所必备的基本能力。
ASP.NET中DataGrid的高级技巧[官方视频]
DataGrid自定义列标题 DataGrid自定义列标题 DataGrid自定义列标题 DataGrid自定义列标题 DataGrid自定义列标题
DataGrid导出EXCEL的几个方法(WebControl).rar
在WPF的 DataGrid控件中显示图片的小例子
WPF中的DataGrid合并单元格,模板列内嵌套DataGrid,非真正合并
本列子不使用ToolKit(有3.5和4.0的限制),添加一个类,重写DataGrid。可以在DataGrid上下左右绑定一个DataGrid,类似Footer属性。示例可直接运行,简单易懂。 (思路:两个DataGrid(mainDG,bottomDG),bottomDG...