打印

[asp.net教程] asp.net 2.0服务器控件开发之控件样式2

asp.net 2.0服务器控件开发之控件样式2

重写样式属性
   
    样式属性的重载与其他属性的重载没有裁辞稹h欢谑迪止讨斜匦胱⒁獾氖牵允粜灾邓鞯男薷谋匦肷洗丶腃ontrolstyle属性。下面列举了一个示例应用程序,其重写了table控件的样式属性cellspacing和caption。服务器控件源代码如下所示。
   
  using system;
  using system.collections.generic;
  using system.componentmodel;
  using system.text;
  using system.web;
  using system.web.ui;
  using system.web.ui.webcontrols;
  namespace webcontrollibrary{
   [defaultproperty("text")]
   [toolboxdata("<{0}:webcustomcontrol runat=server></{0}:webcustomcontrol>")]
   public class webcustomcontrol : table {
    //创建构造函数
    public webcustomcontrol() {
     base.caption = "工作安排列表";
     base.cellspacing = 0;
    }
    // 重写cellspacing属性
    [ bindable(false), browsable(false), defaultvalue(0) ]
    public override int cellspacing {
     get {
      return base.cellspacing;
     }
     set {
      throw new notsupportedexception("不能设置cellspacing属性.");
     }
    }
    //重写caption属性
    [defaultvalue("工作安排列表")]
    public override string caption {
     get { return base.caption; }
     set { base.caption = value; }
    }
   }
  }
   
    以上代码主要用于说明重写样式属性的实现方法。具体分析如下所示。
   
    (1)控件类webcustomcontrol继承自table。这样,自定义控件则自动继承了table控件所具有的所有样式属性。这为重写样式属性奠定了基础。
   
    (2)在控件类的构造函数中设置了caption和cellspacing的属性值。
   
    (3)重写cellspacing属性。通过元数据属性标记设置了该属性不可被数据绑定(bindable),告诉设计器该属性不可被浏览(browsable),最后设置了默认值为0(defaultvalue)。另外,在cellspacing属性的设置操作中定义了一个异常。当开发人员设置该属性时将显示该异常。
   
    (4)重写caption属性,为该属性设置默认值。
   
    可能有些读者认为构造函数的设置内容没有什么意义。实际上,实现本例的核心就在于此。只有在构造函数中设置新的属性值,才能够将新值传递给controstyle属性。因为controlstyle属性主要完成的工作是负责样式状态管理以及样式属性的生成。如果没有把改变传到controlstyle,那么重写的样式属性就不会按照预期的那样显示。
   
    下面列举了为测试自定义控件webcustomcontrol而创建的default.aspx页面源代码。
   
  <%@ page language="c#" autoeventwireup="true" codefile="default.aspx.cs" inherits="_default" %>
  <%@ register tagprefix="wcc" namespace="webcontrollibrary" assembly="webcontrollibrary" %>
  <!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
  <html xmlns="http://www.w3.org/1999/xhtml">
  <head runat="server">
  <title>重写样式属性</title>
  </head>
  <body>
   <form id="form1" runat="server">
    <div>
    <wcc:webcustomcontrol id="demo1" runat="server" font-size="small" borderwidth="1px" cellpadding="4" bordercolor="black" gridlines="both">
    <asp:tablerow>
     <asp:tablecell font-bold="true" runat="server">工作项目</asp:tablecell>
     <asp:tablecell font-bold="true" runat="server">截至日期</asp:tablecell>
     <asp:tablecell font-bold="true" runat="server">备注</asp:tablecell>
    </asp:tablerow>
    <asp:tablerow runat="server">
     <asp:tablecell runat="server">工作1</asp:tablecell>
     <asp:tablecell runat="server">7月17日</asp:tablecell>
     <asp:tablecell runat="server">备注内容</asp:tablecell>
    </asp:tablerow>
    <asp:tablerow runat="server">
     <asp:tablecell runat="server">工作2</asp:tablecell>
     <asp:tablecell runat="server">7月27日</asp:tablecell>
     <asp:tablecell runat="server">备注内容</asp:tablecell>
    </asp:tablerow>
    <asp:tablerow runat="server">
     <asp:tablecell runat="server">工作3</asp:tablecell>
     <asp:tablecell runat="server">7月29日</asp:tablecell>
     <asp:tablecell runat="server">备注内容</asp:tablecell>
    </asp:tablerow>
   </wcc:webcustomcontrol>
  </div>
  </form>
  </body>
  </html>
   
    下面显示了示例应用效果图。
   
   
   根据default.aspx源代码以及应用效果图可知,上图中的表格标题(caption),以及相邻表格间距(cellspacing)均由自定义控件内置设置,而不是通过控件的显式标记来完成。这就是重写控件样式属性的结果。
   
    小结
   
    本文首先对服务器控件样式的基本知识进行了简要介绍,然后,通过一个典型示例说明了重写控件样式属性的方法。希望读者通过这些内容,能够对服务器控件样式属性建立一个更为深入的理解。在随后的文章中,我们将讲解实现样式属性的具体方法。

TOP

返回顶部
AYBlue

Processed in 0.061440 second(s), 7 queries.

当前时区 GMT+8, 现在时间是 2009-1-10 11:47 京ICP备06054220号

清除 Cookies - 联系我们 - 163K.com - Archiver - WAP