您的位置:首页 > 移动开发 > Objective-C

为DataGrid创建自定义列控件(一)

2005-10-28 13:43 363 查看
DataGrid中为我们提供了5种常用的列控件

•      BoundColumn
•      ButtonColumn
•      EditCommandColumn
•      HyperLinkColumn
•      TemplateColumn

通常情况下,这5种列控件都能够完成我们大部分的开发,但是有时遇到特殊情况下,为了简化开发,自定义列控件就派上的用场。
在开发以前,让我们先来了解下列控件的基础知识:
所有的列控件都是来自System.Web.UI.WebControls命名空间,比如BoundColumn来自System.Web.UI.WebControls.BoundColumn命名空间。所有的这些控件都来自DataGridColumn类。
DataGridColumn类具有的属性:
FooterStyle      获取列的脚注部分的样式属性。
FooterText      获取或设置列的脚注部分中显示的文本。
HeaderImageUrl      获取或设置列的页眉节中显示的图像的位置。
HeaderStyle      获取列的页眉节的样式属性。
HeaderText      获取或设置在列的页眉节中显示的文本。
ItemStyle      获取列的项单元格的样式属性。
SortExpression      获取或设置选择进行排序的列时传递到 OnSortCommand 方法的字段或表达式的名称。
Visible      获取或设置一个值,该值指示此列在 DataGrid 控件中是否可见。
DataGridColumn类有两个很重要的方法必须提出,一是Initialize方法,二是InitializeCell方法。Initialize方法提供基实现以将从 DataGridColumn 类派生的列重置为它的初始状态。InitializeCell 方法提供基实现以将从 DataGridColumn 类派生的列中的指定单元格重置为它的初始状态。(具体这两个方法的说明请大家自行查阅)
好了,说了那么多废话,让我们马上进入到自定义列控件的开发。
我们先来做一个非常简单的列控件,功能就是显示指定的文字。
首先创建一个类库项目,命名为SimpleColumn,然后创建继承自DataGridColumn类的HelloColumn类,代码如下:


using System;


using System.Web;


using System.Web.UI;


using System.Web.UI.WebControls;




namespace SimpleColumn






{




      /**//// <summary>


      /// Class1 的摘要说明。


      /// </summary>


      public class HelloColumn : DataGridColumn




      

{


            public override void InitializeCell(TableCell cell, int columnIndex, ListItemType itemType)




            

{


                  base.InitializeCell (cell, columnIndex, itemType);


                  if((itemType == ListItemType.AlternatingItem)||(itemType == ListItemType.SelectedItem)||(itemType == ListItemType.Item))




                  

{


                        cell.Text = "Hello";


                  }


            }




      }


}



最后在页面上引用这各类




<%

@ Register TagPrefix="custCols" Namespace="SimpleColumn" Assembly="SimpleColumn" %>在DataGrid中添加Column,如下:


<Columns>


      <custcols:HelloColumn></custcols:HelloColumn>


</Columns> 
最后效果:


 
        这样一个简单的自定义列控件就创建好了,是不是很简单呢?由于是继承DataGridColumn类,所以在显示的时候大家还可以设置这个列控件的页眉文字等属性。
     
        接下来,我们再来创建一个带自定义属性的列控件。这个列控件主要完成的任务就是可以自定义文字的显示个数,多余的部分用…显示,相信大家经常遇到这样的情况吧。
        首先我们创建一个继承自BoundColumn类的LimitColumn类。BoundColumn类继承自DataGridColumn类,用来显示数据源中的字段内容。LimitColumn控件将会用到BoundColumn类中的FormatDataValue方法,此方法用来指定显示字段内容的格式。
然后设置自定义字数属性CharLimit,具体代码如下:


public class LimitColumn : BoundColumn




      

{


            private int m_CharLimit = -1;


            public int CharLimit




            

{


                  get




                  

{


                        return this.m_CharLimit;


                  }


                  set




                  

{


                        if(value>=0)




                        

{


                              this.m_CharLimit = value;


                        }


                        else




                        

{


                              this.m_CharLimit = -1;


                        }


                  }


            }




            protected override string FormatDataValue(object dataValue)




            

{


                  if(this.m_CharLimit == -1)




                  

{


                        return base.FormatDataValue (dataValue);


                  }


                  else




                  

{


                        string defValue = base.FormatDataValue (dataValue);


                        if(defValue.Length < this.m_CharLimit)




                        

{


                              return defValue;


                        }


                        else




                        

{


                              return defValue.Substring(0,this.m_CharLimit)+"

";


                        }


                  }


            }





在页面上设置:

在页面上设置:


<Columns>


                              <custcols:LimitColumn CharLimit="2" DataField="ShipCountry"></custcols:LimitColumn>


                        </Columns> 
效果如下:


 
通过这两个简单的例子,相信大家对自定义列控件有了大概的认识了。在以后的文章中,我们将看到更为复杂的自定义列控件的介绍。
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息