I have a select box. The options have been styled with different colors via a CSS file that has been referenced. I want to be able to select an option and change the text color of the closed select box to the color of the chosen option.
<select id="mySelect" class="yellowText"> <option class="greenText" value="apple" >Apple</option> <option class="redText" value="banana" >Banana</option> <option class="blueText" value="grape" >Grape</option> </select>
So if I select Banana, the text should change from yellow to red.
I have tried:
onchange="this.style.color = this.options[this.selectedIndex].style.color;"
But this only works if I define my styles within the option tags inside html document.
I have also tried JavaScript:
function setSelectColor(thisElement){ var thisElem = document.getElementById(thisElement); var thisOption = thisElem.options[thisElem.selectedIndex]; var newColor = getStyle(thisOption,"color"); alert("New Color: "+ newColor); }
But this always returns the color: white. The getStyle function works everywhere else I use it so I do not believe that's the problem.
I got getStyle from this very website:
function getStyle(oElm, strCssRule){ var strValue = ""; if(document.defaultView && document.defaultView.getComputedStyle){ strValue = document.defaultView.getComputedStyle(oElm, "").getPropertyValue(strCssRule); } else if(oElm.currentStyle){ strCssRule = strCssRule.replace(/\-(\w)/g, function (strMatch, p1){ return p1.toUpperCase(); }); strValue = oElm.currentStyle[strCssRule]; } return strValue; }
How can I solve this with JavaScript?
To change the selected option background-color CSS style, we can set the style attribute of the select and option elements. to set the whole select element to background color 009966 and color FFF . Then we override the the styles in the option elements with style="background: white; color: black;" .
You can change the background color and color of selected text by styling ::selection . Styling this pseudo element is great for matching user-selected text to your sites color scheme.
The colour of selected text can be easily changed by using the CSS | ::selection Selector. In the below code, we have used CSS ::selection on <h1> and <p> element and set its colour as yellow with green background.
To change some of the text in the HTML document to another color use the FONT COLOR Tag. To change the color of the font to red add the following attribute to the code to the <FONT COLOR=" "> tag. #ff0000 is the color code for red.
Try this:
.greenText{ background-color:green; } .blueText{ background-color:blue; } .redText{ background-color:red; }
<select onchange="this.className=this.options[this.selectedIndex].className" class="greenText"> <option class="greenText" value="apple" >Apple</option> <option class="redText" value="banana" >Banana</option> <option class="blueText" value="grape" >Grape</option> </select>
ONE COLOR CASE - CSS only
Just to register my experience, where I wanted to set only the color of the selected option to a specific one.
I first tried to set by css only the color of the selected option with no success.
Then, after trying some combinations, this has worked for me with SCSS:
select { color: white; // color of the selected option option { color: black; // color of all the other options } }
Take a look at a working example with only CSS:
select { color: yellow; // color of the selected option } select option { color: black; // color of all the other options }
<select id="mySelect"> <option value="apple" >Apple</option> <option value="banana" >Banana</option> <option value="grape" >Grape</option> </select>
For different colors, depending on the selected option, you'll have to deal with js.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With