GridView内容详解(1)
GridView是ASP.NET界面开发中的一个重要的控件,对GridView使用的熟练程度直接影响软件开发的进度及功能的实现。
GridView的主要新特性:
1.与DataSource控件结合实现了显示与数据操作的分离,大大减化了代码的编写量;
2.实现"双向绑定",无需手动检索数据。
2.在列的类型上新增了CheckBoxField和ImageField两个类型列;
3.对排序和分页可以实现异步操作;
4.对其视图状态进行优化,使其运行效率更高;
GridView与DataSource控件
要谈GridView就必需要谈DataSource,这两个对象可称得上是“最佳拍档”。DataSource控件
负责与数据源的交互,而GridView负责数据的显示。它们之间通过“双向绑定”联系起来,即DataSource控件将检索出来的数据绑定到GridView中显示,而GridView中修改和删除的数据直接绑定到DataSource数据源去。这两个过程由这两个控件相互配合实现的,无需我们编写代码。如果我们只用GridView显示数据,而不用DataSource控件的话,那你只好编写代码实现DataSource要作的工作了。做为用过VS2003的用户对这个工作并不陌生,但这种代码实现不但工作量大,而且使用复杂,容量产生大量可读性差的代码,当然也是初学者的最大障碍。好在VS2005为我们提供了DataSource控件,使我们不再如此痛苦地Coding了(当然,如果有的情况下DataSource控件还无法完全替代Coding)。
所以在使用GridView控件的时候我们最好配合DataSource控件使用,不要再去折磨自己了。下面的案例不做特殊说明均以GridView+DataSource控件实现。
一、GridView外观设置:
1、总体外观设置
ShowFooter:(bool)是否显示页脚
ShowHeader:(bool)是否显示页眉
GridLines:(enum)None-不显示格线;Horizontal-显示水平格线;Virtical-显示竖直格线;Both-显示水平和竖直格线
EmptyDataText:(string)如果数据源中内容为NULL时在GridView中显示的值
AlternatingRowStyle:交替项的样式
EditRowStyle:编辑项的样式
EmptyDataRowStyle:空数据项的样式
FooterStyle:页脚样式
HeaderStyle:页眉样式
PagerStyle:分页样式
RowStyle:行样式
SelectedRowStyle:选中项样式
注:1、使用GridView的时候我们一般可以使用“自动套用样式”选中一个样式,然后在此样式的基础上修改上面的属性,从而制作出满意外观效果。
2、上面的样式可以对GridView进行总体的外观设置,如果对某一列进行设置的话那可要在GridView右上角“智能菜单中”点击“编辑列”进行设置。
如:
修改RowStyle-BackColor、RowStyle-Font、RowStyle-HorizontalAlign 等属性后           
2、对绑定列进行外观设置
对上面的图我们可以看出外观方面有几个问题:
a.页眉是英文的
b.所有的数据都是居中对齐
c.time列的数据中显示了时分秒的数据
d.price列中应加上"RMB"的符号
e.最好对价格列的数据以红字体显示
上面的这些问题我们可以通地单独对列进行格式设置来实现
点击GridView右上角“智能菜单中”点击“编辑列”,打开"字段"窗口:
这个图总体可以分作三大部分:可用字段,选中的字段,BoundField属性
(1)“可用字段”:显示了可供我们使用的列的类型
BoundField:绑定列,将数据库中的数据以字符形式绑定显示
CheckBoxField:复选框列,一般用来绑定数据库中的Bit型数,以复选框的形式显示在GridView中
gridview不显示HyperLinkField:超链接列,可以用数据源中的数据作超链接文本也可以把所有超链接文本
设为统一的文本
ImageField:图片列,绑定数据源中的图片路径,并把图片显示出来
CommandField:命令列,常用的“选择”,“删除”,“编辑、更新、取消”
ButtonField:按钮列,其它做用的按钮
TemplateField:模板列,可以更灵活地自定义显示格式
(2)“选定的字段”:从“可用字段”中添加进来的,用来在GridView中显示的列。其下方有个复选框“自动生成字段”,如果选中了就会根据DataSource控件中检索出来的数据自动生成列,如果你要自己设置列的格式,请将此复选框清空。
(3)“BoundField属性”:设置“每个可用字段”的属性
我们可以根据自己的需要从“可用字段”中选择列添加到“选中的字段中”,然后设置BoundField属性。
在此我们先主要看BoundField列,其它类型的列后面再讲解。
BoundField中的重要属性:
ControlStyle:当前列中控件的样式
HeaderStyle:当前列中页眉的样式
FooterStyle:当前列中页脚的样式
ItemStyle:当前列中数据行的样式
ReadOnly:当前列是否是只读列,编辑的时候不显示文本框
Sortexpression_r_r:排序表达式,这里只填数据源的列名
Visible:当前列是否可见
HeaderText:页眉文本
FooterText:页脚文本
DataField:当前列的数据行要显示哪个字段的数据,填写字段名
DataFormatString:对显示的数据进行格式化显示
上面的属性太多,大家可以一时记下来,其实也没必要去记,只要见文知意就可以了。下面我们就用上面的内容来解决外观方法的问题
第一步:清空“自动生成字段”复选框
第二步:从“可用字段”中选择“BoundField”添加到“选定的字段”中
第三步:点击“选定的字段”中的每个字段,在“BoundField属性”中设置
HeaderText--页眉文本。如:“汽车名称”
DataField--要在此列显示数据的列名
第四步:设置"name"列的ItemStyle中的HorizontalAlign属性为left,这样只把name列的数据左对齐
第五步:设置"price"列的ItemStyle中的HorizontalAlign属性为right,这样只把price列的数据右对齐
第六步:在time列的DataFormatString属性中设置为:"{0:d}"
第七步:在price列的DataFormatString属性中设置为:"<font color=red>RMB</font>{0}"
好了,大家可以看到上面的问题我们都已解决了,效果还可以吧。
3、对数据行进行外观设计
对于列的设计我们可以通过可视化的界面进行设计,但是对于数据行的外观设置就没有那么简单了。由于我们不知道将来有多少行数据显示,也不知道哪一条数据显示在哪一行中,所以很难通过可视化的方式进行设置。但这并不代表我们没有办法根据绑定的数据不同设置不同行的外观。
要解决这个问题我们先来研究一下GridView的绑定数据的过程:
当我们为GridView设置了已配好数据源后,在运行的时候,会把数据源中的数据绑定显示出来。但由于GridView隐藏了自身在数据绑定过程中的构建过程,所以使好多学JavaEE的同学感觉不如在<Table>标记中嵌入for循环清晰,更使有的同学感到“GridView自动生成的
行让人有点不太放心”。其实,这是个思维导向的问题,只要我们理解了在数据绑定时GridView界面的构建过程,就不难发现GridView数据绑定的思路并不复杂。关键的是大家不要羁绊于JavaEE生成表格的思路中,要以一种开放与求知的心态来研究GridView。
实际上在GridView在数据绑定的过程中是逐行实现的。是从GridView最上面的一行(页眉或上分页行)到最下面的一行(页脚或下分页行)逐行建造的。在建造每一行的过程中,又分为两步:创建行和绑定行两个步骤。下面分开说: