日期:2013-03-26  浏览次数:20429 次

大家可能都用过Asp.net中的DropDownList控件,该控件有一个Items的集合属性,用于设置组合框的下拉选项。这种体贴的做法让用户倍感温馨,现在,我们也发挥一下自己的的才智,创建一个相同功能的属性。

我们将要创建的控件叫WebPanel,该控件用于网站导航,并且可以收缩,外观如下:



第一个图是未收缩的效果,第二个是收缩后的效果,虽然不炫,但是足可以说明问题了。

接下来再看一幅图:




这里,就是Collection属性的编辑器,今天我们就围绕这种效果展开话题。



在上面的Collection属性的编辑器中,主要分成两个部分,左边的部分是对象的集合,右边部分是选定对象的属性,我们可以对每个属性进行设置赋值。



首先,我们定义一个类:StringItem,该类有两个自定义属性:Text用于显示的文本,HyperText是导航的超链接。

using System;

using System.Web.UI;



namespace NSWebPanel

{

/// <summary>

/// StringItem 的摘要说明。

/// </summary>

///

public class StringItem : System.Web.UI.Control , IStateManager

{

private string _Text;

private string _HyperText;



public StringItem()

{

//

// TODO: 在此处添加构造函数逻辑

//

}



public string Text

{

set

{

_Text = value;

}

get

{

return _Text;

}

}



public string HyperText

{

set

{

_HyperText = value;

}

get

{

return _HyperText;

}

}

#region IStateManager 成员



void IStateManager.TrackViewState()

{

base.TrackViewState();

}



bool IStateManager.IsTrackingViewState

{

get

{

return base.IsTrackingViewState;

}

}



object IStateManager.SaveViewState()

{

return base.SaveViewState();

}



void IStateManager.LoadViewState(object state)

{

base.LoadViewState(state);

}



#endregion

}

}



然后,再创建一个用于存放多个StringItem对象的类:StringItems,需要注意的是:该类要继承CollectionBase,这样才能使用默认的Collection属性编辑器。

using System;

using System.Collections;

using System.Web.UI;



namespace NSWebPanel

{

/// <summary>

/// StringItems 的摘要说明。

/// </summary>

public class StringItems : CollectionBase , IStateManager

{

private bool marked;



public StringItems() : base()

{

//

// TODO: 在此处添加构造函数逻辑

//

}



private void Initialize()

{

marked = false;

}



public StringItem this[int index]

{

get

{

return (StringItem)base.List[index];

}

set

{

List[index] = value;

}

}



public void Add(StringItem aItem)

{

base.List.Add(aItem);

}



public void Remove(int index)

{

if(index < base.Count - 1 && index > 0 )

{

bas