Click here to Skip to main content
15,890,282 members
Articles / Web Development / HTML
Article

Custom ComboBox server control for ASP.NET

Rate me:
Please Sign up or sign in to vote.
3.82/5 (19 votes)
5 May 2005 237.6K   2.3K   44   37
A custom ComboBox control for ASP.NET.

Sample Image

Introduction

In my work, I needed a ComboBox Server Control, and there wasn't one with the specifications I needed. After much searching and trying, none of them satisfied my requirement, I need one which could behave like a dropdownlist absolutely and could get an input value. But I got a HTML combobox control from here, which was what I was looking for. So I developed a ComboBox Server Control based on this HTML combobox control and decided to share it with all.

Background

The HTML component is built by using one textbox and one Select, the Select is dynamically repositioned at runtime. My work encapsulates the HTML component as an ASP.NET server control and you can use it like a typical listcontrol in ASP.NET.

Using the code

You can use this control in three ways as follows:

C#
for(int i=1; i < 10; i++)
{
    ComboItem item = new ComboItem("Item"+i.ToString());
    ComboBox1.Items.Add(item);
}
ASP.NET
<bestcomy:ComboBox id="ComboBox2" runat="server" Width="120px">
    <BESTCOMY:COMBOITEM Text="Item1"></BESTCOMY:COMBOITEM>
    <BESTCOMY:COMBOITEM Text="Item2"></BESTCOMY:COMBOITEM>
    <BESTCOMY:COMBOITEM Text="Item3" Selected="true"></BESTCOMY:COMBOITEM>
    <BESTCOMY:COMBOITEM Text="Item4"></BESTCOMY:COMBOITEM>
</bestcomy:ComboBox>
C#
DataTable dt = new DataTable();
dt.Columns.Add("text", typeof(string));
for(int i=1; i < 10; i++)
{
    DataRow ndr = dt.NewRow();
    ndr["text"] = "Item" + i.ToString();
    dt.Rows.Add(ndr);
}

ComboBox3.DataSource = dt.DefaultView;
ComboBox3.DataTextField = "text";
ComboBox3.DataBind();

Points of Interest

Keeping viewstate in the round trip is really interesting. You can see how I achieved this, in the following script:

ComboBox.cs

C#
protected override void TrackViewState()
{
    base.TrackViewState ();
    ((IStateManager)this.Items).TrackViewState();
}

protected override object SaveViewState()
{
    object obj1 = base.SaveViewState();
    object obj2 = ((IStateManager)this.Items).SaveViewState();
    object obj3 = this.Text;
    if(obj1==null && obj2==null && obj3==null)
        return null;
    return new Triplet(obj1,obj2,obj3);
}

protected override void LoadViewState(object savedState)
{
    if(savedState!=null)
    {
        Triplet state = (Triplet)savedState;
        base.LoadViewState(state.First);
        ((IStateManager)this.Items).LoadViewState(state.Second);
        _text = (string)state.Third;
    }
}

ComboItemCollection.cs

C#
public void TrackViewState()
{
    this._IsTrackingViewState = true;
    for(int i=0; i < this._items.Count; i++)
    {
        ((IStateManager)this[i]).TrackViewState();
    }
}

public bool IsTrackingViewState
{
    get
    {
        return this._IsTrackingViewState;
    }
}

public object SaveViewState()
{
    ArrayList list1 = new ArrayList();
    ArrayList list2 = new ArrayList();
    for (int num3 = 0; num3 < this.Count; num3++)
    {
        object obj1 = ((IStateManager)this[num3]).SaveViewState();
        if (obj1 != null)
        {
            list1.Add(num3);
            list2.Add(obj1);
        }
    }
    if (list1.Count > 0)
    {
        return new Pair(list1, list2);
    }
    return null;
}

public void LoadViewState(object state)
{
    if (state == null)
    {
        return;
    }
    if (state is Pair)
    {
        Pair pair1 = (Pair) state;
        ArrayList list1 = (ArrayList) pair1.First;
        ArrayList list2 = (ArrayList) pair1.Second;
        for (int num1 = 0; num1 < list1.Count; num1++)
        {
            int num2 = (int) list1[num1];
            if (num2 < this.Count)
            {
                ((IStateManager)this[num2]).LoadViewState(list2[num1]);
            }
            else
            {
                ComboItem item1 = new ComboItem();
                ((IStateManager)item1).LoadViewState(list2[num1]);
                this.Add(item1);
            }
        }
    }
}

ComboItem.cs

C#
public void TrackViewState()
{
    this._IsTrackingViewState = true;
}

public bool IsTrackingViewState
{
    get
    {
        return this._IsTrackingViewState;
    }
}

public object SaveViewState()
{
    return new Pair(this._text,this._selected);
}

public void LoadViewState(object state)
{
    if(state!=null && state is Pair)
    {
        Pair p = (Pair)state;
        this._text = (string)p.First;
        this._selected = (bool)p.Second;
    }
}

History

  • 28 April, 2005 - Design time support for Items.
  • 7 April, 2005 - First release.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
Web Developer
China China
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
GeneralComboBox WIDTHS!! Pin
DjIndy235-Aug-05 3:16
DjIndy235-Aug-05 3:16 
Generalhttp://www.metabuilders.com/Tools/ComboBox.aspx Pin
Anonymous27-May-05 2:44
Anonymous27-May-05 2:44 
GeneralCombobox in a table Pin
patriceemery6-May-05 11:12
patriceemery6-May-05 11:12 
GeneralI love it!!! But ... Pin
patriceemery1-May-05 18:24
patriceemery1-May-05 18:24 
GeneralRe: I love it!!! But ... Pin
czeh17-Jun-05 6:23
czeh17-Jun-05 6:23 
GeneralGood work - Shame its not crossbrowser complient Pin
Ian Powell19-Apr-05 5:52
Ian Powell19-Apr-05 5:52 
GeneralRe: Good work - Shame its not crossbrowser complient Pin
DieterAIV3-May-05 0:17
DieterAIV3-May-05 0:17 
QuestionWhat about GridLayout Pin
DCUtility12-Apr-05 11:21
professionalDCUtility12-Apr-05 11:21 
Work A1 in FlowLayout but button lost position in GridLayout!!!

Any trick to this?

Great control anyway!

->L'enfer est pavé de bonnes intentions! :-S
->The road to hell is paved with good intentions! :-S
AnswerRe: What about GridLayout Pin
bestcomy12-Apr-05 13:54
bestcomy12-Apr-05 13:54 
GeneralRe: What about GridLayout Pin
czeh17-Jun-05 5:43
czeh17-Jun-05 5:43 
GeneralNice! (+ some fixes) Pin
FURI-CURI12-Apr-05 2:28
FURI-CURI12-Apr-05 2:28 
GeneralRe: Nice! (+ some fixes) Pin
bestcomy12-Apr-05 2:41
bestcomy12-Apr-05 2:41 
GeneralRe: Nice! (+ some fixes) Pin
FURI-CURI12-Apr-05 4:01
FURI-CURI12-Apr-05 4:01 
GeneralRe: Nice! (+ some fixes) Pin
bestcomy12-Apr-05 4:31
bestcomy12-Apr-05 4:31 
GeneralRe: Nice! (+ some fixes) Pin
FURI-CURI12-Apr-05 19:09
FURI-CURI12-Apr-05 19:09 
GeneralRe: Nice! (+ some fixes) Pin
bestcomy12-Apr-05 19:21
bestcomy12-Apr-05 19:21 
GeneralRe: Nice! (+ some fixes) Pin
FURI-CURI12-Apr-05 20:24
FURI-CURI12-Apr-05 20:24 
GeneralRe: Nice! (+ some fixes) Pin
phyle17-May-05 10:05
phyle17-May-05 10:05 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.