Click here to Skip to main content
Licence CPOL
First Posted 24 Feb 2006
Views 34,634
Bookmarked 24 times

ListItem Control Background Formatting for DropDownList

By | 24 Feb 2006 | Article
An article on a workaround for setting the background color of an ASP.NET DropDownList.

Introduction

If you have found this article then it means that you could not get the background style of a ListItem control to work properly with such web controls as a DropDownList. Yes, it's supposed to work because the ListItem control does contain an Attribute collection, but for some reason, none of the styles nor the supplied attributes will work. Well, a more tedious solution can be found here: List Control Items and Attributes by Scott Mitchell.

My solution, however, works just as well with one (known) flaw. The AutoPostBack property can not be used. I'm sure there are some JavaScript capabilities that can be implemented to duplicate this feature, so we won't consider it a major issue. At this point, you are probably wondering why the AutoPostBack property will be unavailable. Well my question to you is, "Why are you trying to use a DropDownList if its ListItem attributes don't work?".

If the handling of attributes for a DropDownList's ListItems are an obvious bug, then how about the ListItems for a System.Web.UI.HtmlControls.HtmlSelect control? I'm sure you know of all the ways to bind data with ASP.NET controls, so I'm positive that you'll use the simplicities of this example in more advanced ways.

ASPX

<form id="Form1" method="post" runat="server">
  <select name="ddlTest" id="ddlTest" runat="server" style="width:125px">
  </select>
</form>

Code Behind

Protected WithEvents ddlTest As System.Web.UI.HtmlControls.HtmlSelect

Private Sub Page_Load(ByVal sender As System.Object, _
            ByVal e As System.EventArgs) Handles MyBase.Load
    If Not Me.IsPostBack Then
        Dim l As ListItem

        l = New ListItem("Lions", "1")
        l.Attributes.Add("style", "background: yellow;")
        ddlTest.Items.Add(l)

        l = New ListItem("Tigers", "2")
        l.Attributes.Add("style", "background: orange;")
        ddlTest.Items.Add(l)

        l = New ListItem("Bears", "3")
        l.Attributes.Add("style", "background: brown;")
        ddlTest.Items.Add(l)

        l = New ListItem("Oh My!", "4")
        l.Attributes.Add("style", "background: red; color: white;")
        ddlTest.Items.Add(l)
    End If
End Sub

That's It

There's always a solution, even if it is just a quick fix.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Roy Oliver

Software Developer (Senior)
CDC
United States United States

Member



Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
GeneralThinking outside the box.. PinmemberAdam Joyce12:53 16 Sep '09  
GeneralRe: Thinking outside the box.. PinmemberRoy Oliver15:00 28 Sep '09  
GeneralThank you! / C# Pinmembermichaelgcooper17:08 5 May '09  
GeneralRe: Thank you! / C# PinmemberRoy Oliver14:24 7 May '09  
GeneralIt doesn't work if Autopost back is true Pinmembersumitranjansumit5:50 27 Aug '07  
Questionwhy not work? Pinmemberwuxsh0:07 16 May '06  
I copy all code to my page code,but it is not working,why?
AnswerRe: why not work? PinmemberRoy Oliver14:08 17 May '06  

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

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

Permalink | Advertise | Privacy | Mobile
Web02 | 2.5.120529.1 | Last Updated 24 Feb 2006
Article Copyright 2006 by Roy Oliver
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid