DATAGRID经典技巧 [转]很久以前就想写一些关于DataGrid/DataList的东西,但是一直以来,一方面自感所学未深,另一方面,总觉无从下笔,一拖再拖,离刚开始的念头已距一年有余。
DATAGRID经典技巧 [转]DataGrid
/DataList在ASP.NET中的重要性,想必就不用我再强调了,凡显示Table类型的数据,大多会使用这两个控件(当然,如果谁还像ASP那样写ASP.NET,那我也没有办法),所以,每个人可能都有自己的领悟,这篇文章,算是抛砖引玉,为大家做个铺垫。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]一、方法
DATAGRID经典技巧 [转]
1、DataBind
DATAGRID经典技巧 [转]很简单、最常用的方法。绑定数据用。需要注意的只有一点:执行了这个方法后,DataGrid(由于DataGrid和DataList极为相似,所以下面的介绍虽然是针对DataGrid,但与DataList也相差不远)里面所有的显示绑定数据的控件,都会显示DataSource里的数据,其余控件也将初始化成.aspx里设计的状态。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]二、属性
DATAGRID经典技巧 [转]
1、DataSource
DATAGRID经典技巧 [转]有DataBind的地方,就应该有DataSource。如果没有指定DataSource而执行DataBind,那DataGrid将什么也不会显示。
DATAGRID经典技巧 [转]DataSource一般是DataSet、DataTable或者DataView。当然也可以绑定DataReader或者其他实现IEnumerable的类。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
2、DataKeyField,DataKeys
DATAGRID经典技巧 [转]当你在DataGrid中定位一行之后,肯定想知道这行在数据表里的位置,至少有五种方法可以做到这一点,设置DataGrid的DataKeyField就是这几种方法之一。
DATAGRID经典技巧 [转]DataKeyField一般设置为数据表的Unique字段(否则就没意义了),通过DataKey可以得到这一行对应的关键字段的值。
DATAGRID经典技巧 [转]DataKeys是DataKey的集合,通过行的索引来读取相应行的DataKey。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
3、EditItemIndex,SelectedIndex,CurrentPageIndex,SelectedItem
DATAGRID经典技巧 [转]这些属性都很好理解,看名字就知道是什么意思,需要注意的是,设置了EditItemIndex或者CurrentPageIndex后需要重新执行DataBind方法(当然,前面提到过,还需要设置DataSource)。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
4、Columns
DATAGRID经典技巧 [转]没什么好解释的,Columns就是Columns,列的集合,可以设置列的属性,包括Visible、HeaderText、FooterText、SortExpression等。
DATAGRID经典技巧 [转]严重注意:自动生成的列,是不包含在Columns中的。只有在.aspx中显示声明的列和在代码中添加的列才会被包含在其中。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
5、Items
DATAGRID经典技巧 [转]俗话说,最后的都是最重要的,把Items作为最后一个属性来介绍,正式基于这样的理由。
DATAGRID经典技巧 [转]Items是DataGridItem的集合,可以遍历当前DataGrid中显示数据的DataGridItem。
DATAGRID经典技巧 [转]
5.1、DataGridItem
DATAGRID经典技巧 [转]每一个DataGridItem就是DataGrid中显示的一行,其中包括:
DATAGRID经典技巧 [转]Header   DataGrid 控件的标题部分
DATAGRID经典技巧 [转]Item   DataGrid 控件中的项
DATAGRID经典技巧 [转]AlternatingItem  DataGrid 控件中的交替项
DATAGRID经典技巧 [转]SelectedItem    DataGrid 控件中的选定项(由SelectedIndex设置,通过SelectedItem属性或者Items[SelectedIndex]来读取)
DATAGRID经典技巧 [转]EditItem    DataGrid 控件中处于编辑状态的项(由EditItemIndex设置,通过Items[EditItemIndex]来读取)
DATAGRID经典技巧 [转]Separator    DataGrid 控件中项之间的分隔符
DATAGRID经典技巧 [转]Footer    DataGrid 控件的脚注部分
DATAGRID经典技巧 [转]Pager     DataGrid 控件的页选择节
DATAGRID经典技巧 [转]注意,DataGrid的Items属性中不会包含Header、Footer、Pager这三类DataGridItem的。
DATAGRID经典技巧 [转]
5.1.1、DataGridItem的属性
DATAGRID经典技巧 [转]ItemIndex 
-- 得到行在Items中的索引
DATAGRID经典技巧 [转]ItemType 
-- 返回行的类型,也就是上面列出的Header、Item、DATAGRID经典技巧 [转]、Pager
DATAGRID经典技巧 [转]Cells 
-- 返回行包含的所有TableCell(不管是显示声明的,还是自动生成的,不管是可以看见的,还是隐藏掉的),通过TableCell,可以读取Cell中显示的文本、包含的控件
DATAGRID经典技巧 [转]严重注意:只有BoundColumn列和自动生成列,才可以通过TableCell.Text属性读取显示的文本。HyperLinkColumn、ButtonColumn、EditCommandColumn都需要将目标控件转换成相应的控件。
DATAGRID经典技巧 [转]比如:
DATAGRID经典技巧 [转]假设DataGrid的第一列声明如下
DATAGRID经典技巧 [转]
<asp:HyperLinkColumn DataTextField="au_id" HeaderText="au_id" DataNavigateUrlField="au_id" DataNavigateUrlFormatString="Edit.aspx?id={0}"></asp:HyperLinkColumn>
DATAGRID经典技巧 [转]读取的时候可以用:
DATAGRID经典技巧 [转]
//Items[0]表示第一行,Cells[0]表示第一列,Controls[0]表示Cell中的第一个控件(也只有这个控件可以用)
DATAGRID经典技巧 [转]
HyperLink link = (HyperLink)DataGrid1.Items[0].Cells[0].Controls[0]);
DATAGRID经典技巧 [转]Response.Write(link.Text);
DATAGRID经典技巧 [转]至于模板列(TemplateColumn),当然也可以通过DataGrid1.Items[i].Cells[j].Controls[n]来获取,然后转换成原来的控件类型再操作,但是还有个更好的办法,就是用FindControl来查找控件。
DATAGRID经典技巧 [转]FindControl是System.Web.UI.Control的方法,可以根据子控件ID来查找子控件
DATAGRID经典技巧 [转]比如:
DATAGRID经典技巧 [转]假设DataGrid的某一列声明如下
DATAGRID经典技巧 [转]
<asp:TemplateColumn>
DATAGRID经典技巧 [转]   
<ItemTemplate>
DATAGRID经典技巧 [转]      
<asp:TextBox Runat="server" ID="txtID" Text='<%# DataBinder.Eval(Container.DataItem,"au_id") %>'>
DATAGRID经典技巧 [转]      
</asp:TextBox>
DATAGRID经典技巧 [转]   
</ItemTemplate>
DATAGRID经典技巧 [转]
</asp:TemplateColumn>
DATAGRID经典技巧 [转]读取方法:
DATAGRID经典技巧 [转]TextBox txt 
= (TextBox)DataGrid1.Items[1].FindControl("txtID");
DATAGRID经典技巧 [转]Response.Write(txt.Text);
DATAGRID经典技巧 [转]注意:DataList中是没有Cell的
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]三、事件
DATAGRID经典技巧 [转]
1、ItemCommand、CancelCommand、DeleteCommand、EditCommand、UpdateCommand
DATAGRID经典技巧 [转]也就是DataGrid中,点击Button、LinkButton后执行的事件,执行的事件取决于按钮的CommandName。其实最主要的一个是ItemCommand,而后面四个都只是ItemCommand的一小部分,
DATAGRID经典技巧 [转]比如一个按钮的CommandName为
"Cancel",当返回后,首先执行的是ItemCommand事件,然后才是CancelCommand事件。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
2、PageIndexChanged
DATAGRID经典技巧 [转]如果你的DataGrid是分页的,那当你在DataGrid上点击Pager上的1、
2、3或者<>时,就会激发这个事件。
DATAGRID经典技巧 [转]在这个事件里面,你可以用e.NewPageIndex来读取要改变的页,然后赋值给DataGrid的CurrentPageIndex属性,最后不要忘了,还要设置DataSource,还要执行DataBind。
DATAGRID经典技巧 [转]注意:DataList中没有这个事件,如果需要在DataList中分页,可以一段一段的读取数据,然后把当前段的数据绑定到DataList上。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
3、ItemDataBound,ItemCreated
DATAGRID经典技巧 [转]首先要说的是这两个事件的发生时间。
DATAGRID经典技巧 [转]ItemDataBound嘛,只要执行了DataBind方法,就会马上激发这个事件。
DATAGRID经典技巧 [转]ItemCreated呢,如果页面是第一次访问(Page.IsPostBack 
= false),那在第一次执行DataBind的时候,会先激发ItemCreated事件,也就是说,执行了DataBind后,首先会用ItemCreated来建立Header行,然后用ItemDataBound来绑定Header行,再用ItemCreated来建立第一行,再调用ItemDataBound来绑定第一行,也就是说ItemCreated和ItemDataBound是交替执行的。
DATAGRID经典技巧 [转]页面返回时,也会执行ItemCreated事件,在Page_Load之前,但是这时候就不会再执行ItemDataBound事件了。
DATAGRID经典技巧 [转]所以,如果你想在DataGrid里动态添加什么控件,就需要在ItemCreated事件中,而不是在ItemDataBound事件中。
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]
DATAGRID经典技巧 [转]四、代码片断
DATAGRID经典技巧 [转]
1、DataGrid显示双层表头
DATAGRID经典技巧 [转]假设你的DataGrid有三列,现在想将前两列作为
"大类1",第三列作为"大类2",现在,你可以在ItemDataBound事件中加入下面的代码:
DATAGRID经典技巧 [转]
if (e.Item.ItemType == ListItemType.Header)

相关文章: