Go homepage(回首页) Upload pictures (上传图片) Write articles (发文字帖)
The author:(作者)delvpublished in(发表于) 2014/1/8 7:00:56 ASP.NET,2.0服务器控件开发之控件样式_[Asp.Net教程]
上面的代码比较简单。Style对象实例s1在调用CopyFrom方法之后,其ForeColor的属性值将被修改为Color.White;s1在调用MergeFrom之后,其ForeColor的属性值则不变,仍然为Color.Red。
重写样式属性 样式属性的重载与其他属性的重载没有什么区别。然而,在实现过程中必须注意的是,对属性值所作的修改必须上传给控件的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> 下面显示了示例应用效果图。
作者:金属边缘出处:天极开发
赞