打印

[asp.net教程] asp.net 2.0服务器控件之复合控件样式1

asp.net 2.0服务器控件之复合控件样式1

为了设置复合控件的外观,复合控件必须提供一些样式属性,尤其是针对子控件的样式属性。在本文中,我们将重点介绍为复合控件实现样式属性的两种方法。
   
    1、上传部分样式属性
   
    在为复合控件实现样式属性之前,读者应首先了解"样式冒泡"的基本概念。样式冒泡多用于实现复合控件的样式属性。由于在复合控件中包含多个子控件,因此,这些子控件的样式属性可能在一定情况下,干扰复合控件的样式属性,引起样式属性混乱。为了更加明确的定义复合控件的样式属性,可以采取将子控件的样式属性上传为顶级样式属性的方法,这就是所谓的"样式冒泡"。
   
    通常情况下,开发人员可能面对两种情况:一种是上传子控件中少数样式属性,另一种是上传子控件中所有样式属性。本小节只介绍针对第一种情况的实现方法,而另外一种将在后面一节中进行讲解。
   
    本节说明的这种实现样式属性的方法,其关键是通过为子控件的attributes指定键/值对,引入样式属性,由此将子控件的样式属性上传为复合控件顶级属性。为了方便读者理解这一方法,下面列举了一个典型应用。
   
    在本示例中,实现了一个复合控件mycontrol,其子控件集合中包括一个table控件。当前,需要将table子控件的样式属性cellpadding和border上传为mycontrol的顶级样式属性。具体源代码如下所示。
   
  public class mycontrol : compositecontrol{
   // 相关代码 ......
   // 定义初始值
   
   private int _cellpadding = 0;
   private int _border = 1;
   ......
   // 定义样式属性,它和table控件的样式属性cellpadding和border类似
   public int cellpadding{
    get { return _cellpadding; }
    set { _cellpadding = value; }
    // 实现属性border
    public int border{
     get { return _border; }
     set { _border = value; }
     ......
     // 重写createchildcontrols方法
     protected override void createchildcontrols() {
      //相关代码

      ......
      table t = new table(); //将前面定义的属性添加到键/值对中   
      t.addattributes.add("cellpadding",_cellpadding.tostring());
      t.addattributes.add("border",_border.tostring());
      ......
     }
   }
   
    以上代码显示了mycontrol的一些关键源代码,其重点在于说明实现部分样式属性冒泡的关键步骤。(1)初始化顶级样式属性的字段,如果有必要可以定义初始值。(2)定义与需要升级的子控件的样式属性相同名称的属性。上面的代码中定义了属性cellpadding和border。(3)在子控件的attributes的键/值对中引入第2步中定义的属性。
   
    当设置mycontrol中的样式属性cellpadding和border的属性值时,实际是设置table子控件的cellpadding和border的属性值。通过以上3个关键步骤就可实现样式冒泡。
   
    如果读者仔细观察可以发现,以上介绍的这种实现样式冒泡的方法存在一些问题:一、这种方法只适用于升级子控件中少数样式属性。如果需要将子控件的所有样式属性都升级,而仍然使用这种方法,则实现起来非常繁琐,容易产生错误。二、所实现的样式属性缺乏逻辑性和组织性。在某种情况下,例如,多个子控件的同一样式属性都需要升级为顶级属性,这时使用该方法将会引起混乱。
   
    为了解决这些问题,下面介绍一种上传子控件全部样式属性的实现方法。

TOP

返回顶部
AYBlue

Processed in 0.048001 second(s), 7 queries.

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

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