原文:asp.net学习之GridView七种字段

asp.net中GridView绑定到数据源时,可以自动显示数据源的各个字段。只要设定其AutoGenerateColumns为TRUE即可。但这,自动显示有其不好的一面,因为不能自义定控制显示的样式。
    解决以上的办法就是指定需要GridView显示的字段,GridView控件支持以下七种类型的Field:
      ● BoundField   :  将数据项显示为文本
      ● CheckBoxField : 将数据项显示为复选框
      ● CommandField : 使用链接来支持编辑、删除或选中行
      ● ButtonField : 将数据项显示为按钮(ImageButton、LinkButton、Button)
      ● HyperLinkField : 将数据项显示为超链接
      ● ImageField : 将数据项显示为图片
      ● TemplateField: 自定义数据项的外观
   以上,各Field的父类都为DataControlFiled.所以,下面先谈谈DataControlField。

1. DataControlField

DataControlField 类用作所有数据控件字段类型的基类。数据绑定控件使用数据控件字段表示数据字段。
     DataControlField定义了一些共公的属性,其子Field都可以使用。
       ● HeaderText/HeaderImageUrl : 标题栏字段/标题栏的图像URL
       ● FooterText : 脚注项的文本
       ● AccessibleHeaderText : 一个字符串,表示由屏幕阅读器读取的缩写文本。
       ● Control: 获取对Field内数据控件的引用
       ● InsertVisible: 插入新记录时,此列是否可见。(不能在GridView控件中使用)
       ● HeaderStyle/FooterStyle/ItemStyle/ControlStyle : 标题项/脚注项/数据项/子WEB控件的样式
       ● SortExpression : 为数据项指定排序表达式

2. 使用BoundField

GridView在显示状态,BoundField总是直接把数据项显示为文本;在编辑状态,BoundFiled将数据项显示为一个单行的文本框
     2.1 BoundField几个种要属性
        除了其父类DataControlField的几个属性外,还有以下几个属性
        ● DataField : 显示的字段
        ● DataFormatString : 字段格式化
        ● HtmlEncode / HtmlEncodeFormatString: 获取或设置一个值,该值指示在 BoundField 对象中显示字段值之前,是否对这些字段值进行 HTML 编码。
      注: FormatString经常用来格式化数字、日期、字符串、自定义类型。
            关于字符格式化,参见以下MSDN:http://msdn.microsoft.com/zh-cn/library/26etazsy.aspx
            或:http://www.cnblogs.com/tianhao960/archive/2006/06/22/433255.html
例1:使用GridView绑定字段

Code<asp:GridView id=”grdMovies” DataSourceID=”srcMovies” AutoGenerateColumns=”false” Runat=”server”>    <Columns>        <asp:BoundField DataField=”Title” HeaderText=”Movie Title” />        <asp:BoundField DataField=”Director” HeaderText=”Movie Director” />        <asp:BoundField DataField=”BoxOfficeTotals” DataFormatString=”{0:c}”                HtmlEncode=”false” HeaderText=”Box Office Totals” />    </Columns></asp:GridView> 

2.2 除了以上这些属性外,还有以下几个属性比较有用
        ● ApplyFormatInEditMode: 若要在编辑模式中将格式化字符串应用到字段值,则为 true;否则为 false。默认为 false。
        ● Readonly:  防止该数据项进入编辑模式。
        ● NullDisplayText : 当数据项为NULL时显示的文本

3. CheckBoxField

CheckBoxField会在相应的列内显示一个复选框,在没有进入编辑模式时,其复杂框处于禁用状态。
    CheckBoxField通过设置 Text 属性,可以在每一个复选框旁边显示一个标题

4. CommandField

使用CommandField可以定制GridView控件中Edit、Delete、Update、Cancel、Select等按钮的外观。
     需要使用CommonField时,不要启用GridView的AutoGenerateEditButton和AutoGenerateDeleteButton属性。因为可以直接使用CommandField
     CommandField的一些属性:
       ● ButtonType:指定Button类型、可以有Button、Image、Link类型
       ● CancelText/CancelImageUrl: Cancel按钮中的文本/图像URL
       ● DeleteText/DeleteImageUrl: Delete按钮中的文本/图像URL
       ● InsertText/InsertImageUrl: Insert按钮中的文本/图像URL
       ● EditText/EditImageUrl: Edit按钮中的文本/图像URL
       ● UpdateText/UpdateImageUrl: Update按钮中的文本/图像URL
       ● SelectText/SelectImageUrl: Select按钮中的文本/图像URL
       ● NewText/NewImageUrl: New按钮中的文本/图像URL
       ● ShowEditButton/ShowDeleteButton/ShowCancelButton/ShowSelectButton/ShowInsertButton: 是否显示相应按钮
       ● CauseValidation:点击按钮时是否启用校验
       ● ValidationGroup: 指定和编辑按钮相关验证控件组的名称

5. ButtonField

使用ButtonField可以在GridView中显示一个按钮,使用它可以完成自定义或标准的编辑命令
     点击GridView中的ButtonField字段,会触发GridView中的OnRowCommand事件。可以在这个事件中处理相关的命令事件。
     ButtonField有以下几个属性
       ● ButtonType : Button类型,可以为Button、Image、LinkButton
       ● CauseValidation : 指定按钮点击时是否引发验证
       ● CommandName : 指定ButtonField关联的标准编辑命令,可以为Delete、Edit、Update、Cancel。或者,可以自定义
       ● DataTextField/DataTextFormatString : 指定按钮文本的数据项/数据项格式
       ● Text : 按钮文本
       ● ValidationGroup : 和按钮相关验证控件组的名称
     通过CommandName属性可以使用BuffonField关联标准的编辑命令,例如给CommandName属性赋"Delete"就可以得到一个具有删除功能的按钮
例2:一个通过点击GridView中的Button,进行数据更新的例子

Code<asp:GridView id=”grdMovieCategories” DataSourceID=”srcMovieCategories” DataKeyNames=”Id,Position”         AutoGenerateColumns=”false” OnRowCommand=”grdMovieCategories_RowCommand” Runat=”server”>    <Columns>        <asp:ButtonField Text=”Move Up” CommandName=”Up” />        <asp:ButtonField Text=”Move Down” CommandName=”Down” />        <asp:BoundField DataField=”Position” HeaderText=”Position” />        <asp:BoundField DataField=”Name” HeaderText=”Category Name” />    </Columns></asp:GridView><asp:SqlDataSource id=”srcMovieCategories” ConnectionString=”<%$ ConnectionStrings:Movies %>”    SelectCommand=”SELECT Id, Name, Position FROM MovieCategories ORDER BY Position”    UpdateCommand=”UPDATE MovieCategories SET Position=@Position WHERE Id=@Id”    Runat=”server”>    <UpdateParameters>        <asp:Parameter Name=”Id” />        <asp:Parameter Name=”Position” />    </UpdateParameters></asp:SqlDataSource> 

6. 使用HyperLinkField

HyperLinkField用来链接到其他页面。当创建两具主从表单的时候,HyperLinkField非常有用。
    HyperLinkField具有以下属性:
       ● DataNavigateUrlFields: 在DataNavigateFormatString中使用的列名称
       ● DataNavigateFormatString: 格式链接字符串
       ● DataTextField/DataTextFormatString: 超链接文本/超链接文本格式化
       ● NavigateUrl: 链接到其它页面的URL
       ● Target : 链接目标,可以使用:_blank/_parent/_self/_top
       ● Text: 超链接的文本
例3:HyperLinkField使用举例,在一个页面中使用frames技术,可以不用整页刷新显示主从表
==FrameMaster.aspx==

Code<asp:GridView id=”grdMovies” DataSourceID=”srcMovies” AutoGenerateColumns=”false” Runat=”server”>    <Columns>        <asp:HyperLinkField HeaderText=”Movies” DataTextField=”Title” DataNavigateUrlFields=”Id”                DataNavigateUrlFormatString=”FrameDetails.aspx?id={0}”  Target=”FrameDetails” />    </Columns></asp:GridView><div class=”column”><iframe name=”FrameDetails” id=”FrameDetails”></iframe></div> 

==FrameDetails.aspx==

Code<asp:DetailsView id=”dtlMovie” DataSourceID=”srcMovieDetails” Runat=”server” /><asp:SqlDataSource id=”srcMovieDetails” ConnectionString=”<%$ ConnectionStrings:Movies %>”      SelectCommand=”SELECT Title, Director, InTheaters FROM Movies WHERE Id=@MovieId”  Runat=”server”>    <SelectParameters>         <asp:QueryStringParameter Name=”MovieId” QueryStringField=”id” />    </SelectParameters></asp:SqlDataSource> 

7. 使用ImageField

ImageFIeld用来显示保存在服务器上的图片,不能用ImageField来显示保存在数据库上的图片。
    ImageField有以下几个属性:
      ● AlternateText : 预备文本
      ● DataAlternateTextField : 使用指定列的值作为预备文本
      ● DataAlternateTextFormatString : 预备文本格式字符串
      ● DataImageUrlField : 存放图片路径的列名
      ● DataImageUrlFormatString : 图片路径格式字符串
      ● NullImageUrl : 指定预备图片
例4: 使用ImageField,实现一个简单的相册

Code<script runat=”server”>protected void frmPhoto_ItemInserting(object sender, FormViewInsertEventArgs e){    // Get the FileUpload control    FileUpload upPhoto = (FileUpload)frmPhoto.FindControl(“upPhoto”);    srcImages.InsertParameters[“FileName”].DefaultValue = upPhoto.FileName;    string savePath = MapPath(“~/Photos/” + upPhoto.FileName);    // Save contents to file system    upPhoto.SaveAs(savePath);}</script><asp:GridView id=”grdImages” DataSourceID=”srcImages” AutoGenerateColumns=”false”        ShowHeader=”false” Runat=”server”>    <Columns>        <asp:ImageField DataImageUrlField=”FileName” DataAlternateTextField=”AltText”             DataImageUrlFormatString=”~/Photos/{0}” ControlStyle-Width=”200px” />    </Columns></asp:GridView><asp:SqlDataSource id=”srcImages” ConnectionString=”<%$ ConnectionStrings:Photos %>”       SelectCommand=”SELECT FileName, AltText FROM Photos” InsertCommand=”INSERT Photos (FileName, AltText)                                 VALUES (@FileName, @AltText)”   Runat=”server”>    <InsertParameters>        <asp:Parameter Name=”FileName” />    </InsertParameters></asp:SqlDataSource><asp:FormView id=”frmPhoto” DefaultMode=”Insert” DataSourceID=”srcImages”         OnItemInserting=”frmPhoto_ItemInserting” Runat=”server”>    <InsertItemTemplate>        <asp:FileUpload id=”upPhoto” Runat=”server” />        <asp:TextBox id=”txtAltText” Text=’<%# Bind(“AltText”) %>’ Columns=”50” Runat=”server” />       <asp:Button id=”btnInsert” Text=”Add New Photo” CommandName=”Insert” Runat=”server” />    </InsertItemTemplate></asp:FormView> 

8.使用TemplateField

使用TemplateField可以在GridView控件的数据列中添加任何内容,例如HTML、数据绑定表达式或者ASP.NET控件等。
   可以使用TemplateField定制用户界面或者给被编辑字段添加验证
    TempateField支持以下6种类型的模板
       ● ALternatingItemTemplate : 间隔行模板
       ● EditItemTemlpate : 编辑行模板
       ● FooterTemplate : 脚注模板
       ● HeaderTemplate : 标题模板
       ● InsertItemTemplate: 插入行模板(不支持GridView控件)
       ● ItemTemplate: 每个显示行模板
例5:TemplateField举例,

Code<asp:GridView id=”grdMovies”   DataSourceID=”srcMovies” DataKeyNames=”Id”       AutoGenerateColumns=”false” AutoGenerateEditButton=”true” Runat=”server”>    <Columns>        <asp:TemplateField HeaderText=”Title”>  <!-- Title 列-->            <ItemTemplate> <%# Eval(“Title”) %> </ItemTemplate> <!-- 注意,是用Eval绑定字绑,而没有BoundField属性了 -->            <EditItemTemplate>  <!-- 编辑时显示的模板 -->                <asp:TextBox id=”txtTitle” Text='<%# Bind(“Title”) %>' Runat=”server” /> <!-- 使用Bind,双向绑定 -->                <-- 编辑时对txtTitle进行验证 -->                <asp:RequiredFieldValidator id=”valTitle” ControlToValidate=”txtTitle” Text=”(required)” Runat=”server” />            </EditItemTemplate>        </asp:TemplateField>        <asp:TemplateField HeaderText=”Category”>  <!-- Category列 -->            <ItemTemplate> <%# Eval(“Name”) %> </ItemTemplate>            <EditItemTemplate>                  <asp:DropDownList id=”ddlCategory” DataSourceID=”srcMovieCategories” DataTextField=”Name”                          DataValueField=”Id” SelectedValue='<%# Bind(“CategoryId”) %>' Runat=”server” />            </EditItemTemplate>        </asp:TemplateField></Columns></asp:GridView>

asp.net学习之GridView七种字段的更多相关文章

  1. asp.net学习之GridView事件、GridViewRow对象

    原文:asp.net学习之GridView事件.GridViewRow对象 1. GridView控件的事件 GridView有很多事件,事件可以定制控件的外观或者行为.事件分为三类     1.1 ...

  2. asp.net学习之扩展GridView

    原文:asp.net学习之扩展GridView 本节讨论如何从现有的控件,进而扩展成强大的,更定制的GridView控件 1.扩展BoundField 默认的BoundField不能显示多文本,文字一 ...

  3. ASP.Net GridView 基础 绑定字段

    通过以前的学习,我们实现了效果如下: 现在我想修改显示/隐藏部分列,有两种做法: 一.在配置数据源的时候不是有查询哪些字段的吗,去除不需要的字段,重新绑定. 二.就是直接编辑列 下面是分析每种字段类型 ...

  4. 【JAVA学习】单例模式的七种写法

    尊重版权:http://cantellow.iteye.com/blog/838473 第一种(懒汉.线程不安全): Java代码   public class Singleton { private ...

  5. ES6学习笔记(八)第七种类型Symbol

    1.概述 ES5 的对象属性名都是字符串,这容易造成属性名的冲突.比如,你使用了一个他人提供的对象,但又想为这个对象添加新的方法(mixin 模式),新方法的名字就有可能与现有方法产生冲突.如果有一种 ...

  6. asp.net学习之ado.net(连接模式访问)

    原文:asp.net学习之ado.net(连接模式访问)    ado.net框架支持两种模式的数据访问: 连接模式(Connected)和非连接模式(disconnected).这一节介绍如何使用连 ...

  7. asp.net学习之SqlDataSource

    原文:asp.net学习之SqlDataSource 通过 SqlDataSource 控件,可以使用 Web 服务器控件访问位于关系数据库中的数据.其中可以包括 Microsoft SQL Serv ...

  8. 我的MYSQL学习心得(七) 查询

    我的MYSQL学习心得(七) 查询 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...

  9. Linux就这个范儿 第15章 七种武器 linux 同步IO: sync、fsync与fdatasync Linux中的内存大页面huge page/large page David Cutler Linux读写内存数据的三种方式

    Linux就这个范儿 第15章 七种武器  linux 同步IO: sync.fsync与fdatasync   Linux中的内存大页面huge page/large page  David Cut ...

随机推荐

  1. 如何解决Android SDK无法下载Package的问题(.net)

    有些用户在安装好Android SDK后,打开Android SDK Manager下载API时一直显示“Done loading packages”却迟迟不能前进,界面显示的Package空空如也. ...

  2. C语言程序代写(Linux下线程)

    联系QQ:928900200 CSCI 3120 Operating Systems Summer 2014 Handout 3Assignment 2Date Due: June 5, 2014 b ...

  3. PV操作——生产者和消费者

    首先,先来看几个概念: 同步:协作的过程,比如,多人开发合作. 相互排斥:争抢资源的过程.比如苦逼的大学选课: 临界区:进程中对临界资源实施操作的那段程序: 临界资源:一次仅仅能一个进程使用的资源,比 ...

  4. 设计模式 - Abstract Factory模式(abstract factory pattern) 详细说明

    Abstract Factory模式(abstract factory pattern) 详细说明 本文地址: http://blog.csdn.net/caroline_wendy/article/ ...

  5. 使用 Gradle 插件进行代码分析(转)

    代码分析在大多数项目中通常是作为最后一个步骤(如果做了的话)完成的.其通常难以配置及与现有代码整合. 本文旨在勾勒出使用 Gradle 整合 PMD 与 FindBugs 的步骤,并将其与一个现有的 ...

  6. 长方柱类【C++ 类定义】

    Description 编写基于对象的程序,求长方柱(Bulk)的体积.数据成员包括长(length).宽(width).高(heigth).体积,要求用成员函数实现下面的功能: (1)由键盘输入长方 ...

  7. Nginx各版本的区别

    Nginx官网提供了三个类型的版本Mainline version:Mainline 是 Nginx 目前主力在做的版本,可以说是开发版Stable version:最新稳定版,生产环境上建议使用的版 ...

  8. HR筒子说:程序猿面试那点事(转)

    小屁孩曾经有过4年的招聘经验,期间见识了各种类型的程序猿:有大牛.有菜牛:有功成名就,有苦苦挣扎不知方向.等后来做了一枚程序猿之后发现,HR眼中的程序猿和程序猿中的HR都是不一样的.有感与此,从HR的 ...

  9. MongoDB时间处理问题

    MongoDB保存到数据库的时候,默认为UTC时间,在数据库保存时,会和当前时间有个间隔,差距为8小时. 在读取的时候,需要再次转换回来,比较麻烦. 其实,Mongo本身就已经提供了相应的处理方法,即 ...

  10. [渣译文] SignalR 2.0 系列: SignalR 自托管主机

    原文:[渣译文] SignalR 2.0 系列: SignalR 自托管主机 英文渣水平,大伙凑合着看吧…… 这是微软官方SignalR 2.0教程Getting Started with ASP.N ...