当前位置:首页 > 网络编程 > WEB编程 > ASP.net >  ASP.NET 2.0服务器控件开发之控件样式(2)

 ASP.NET 2.0服务器控件开发之控件样式(2)

点击次数:19 次 发布日期:2008-11-26 12:52:21 作者:源代码网
源代码网推荐      重写样式属性
源代码网推荐  
源代码网推荐    样式属性的重载与其他属性的重载没有什么区别。然而,在实现过程中必须注意的是,对属性值所作的修改必须上传给控件的ControlStyle属性。下面列举了一个示例应用程序,其重写了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)均由自定义控件内置设置,而不是通过控件的显式标记来完成。这就是重写控件样式属性的结果。
源代码网推荐  
源代码网推荐    小结
源代码网推荐  
源代码网推荐    本文首先对服务器控件样式的基本知识进行了简要介绍,然后,通过一个典型示例说明了重写控件样式属性的方法。希望读者通过这些内容,能够对服务器控件样式属性建立一个更为深入的理解。在随后的文章中,我们将讲解实现样式属性的具体方法。  做人要厚道,请注明转自酷网动力(www.ASPCOOL.COM)。
源代码网推荐


源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华