39

我正在使用一个带有下拉菜单的表单,其中包含一些禁用的选项,因此用户无法选择它们。我正在尝试通过 css 自定义这些元素,但 Chrome 和 IE7/8/9/10 存在一些问题。

HTML:

<div class="formBody">
    <select  name="form[categoria][]"  id="categoria"  class="rsform-select-box">
      <option selected="selected" value="">Scegli una categoria</option>
      <option disabled="disabled" value="">Impresa </option>
    </select>
    <span class="formValidation">
        <span id="component50" class="formNoError">Scegli una categoria</span>
    </span>
</div>

CSS:

select option[disabled] { color: #000; font-weight: bold }

此代码仅适用于 Firefox,不适用于 Chrome 和 IE(所有版本)。

有什么想法可以解决这个问题吗?


在选择框的 html 代码下方

<div class="formBody"><select  name="form[categoria][]"  id="categoria"  class="rsform-select-box" ><option selected="selected" value="">Scegli una categoria</option><option disabled="disabled" value="">Impresa </option><option  value="Servizi">Servizi</option><option  value="Informatica">Informatica</option><option  value="Commercio">Commercio</option><option  value="Telecomunicazioni">Telecomunicazioni</option><option  value="Editoria/Stampa">Editoria/Stampa</option><option  value="Meccanica/Elettrica">Meccanica/Elettrica</option><option  value="Alimentare">Alimentare</option><option  value="Chimica/Farmaceutica">Chimica/Farmaceutica</option><option disabled="disabled" value="">Edilizia </option><option  value="Tessile/Moda">Tessile/Moda</option><option  value="Mobili/Arredamenti">Mobili/Arredamenti</option><option  value="Alberghi/Ristoranti">Alberghi/Ristoranti</option><option  value="Trasporto/Logistica">Trasporto/Logistica</option><option  value="Finanza">Finanza</option><option  value="Altro">Altro</option><option disabled="disabled" value="">Professionista </option><option  value="Commercialista">Commercialista</option><option  value="Ragioniere">Ragioniere</option><option  value="Notaio">Notaio</option><option  value="Tributarista">Tributarista</option><option  value="Avvocato">Avvocato</option><option  value="Consulente del lavoro">Consulente del lavoro</option><option  value="Altro">Altro</option><option disabled="disabled" value="">P.A. Locale </option><option  value="Regione">Regione</option><option  value="Provincia">Provincia</option><option  value="Comune">Comune</option><option  value="Comunit&agrave; Montana">Comunit&agrave; Montana</option><option  value="ASL">ASL</option><option  value="CCIA">CCIA</option><option  value="Altro">Altro</option><option disabled="disabled" value="">P.A. Centrale </option><option  value="Associazione di categoria">Associazione di categoria</option><option  value="Privato">Privato</option><option  value="Altro">Altro</option></select><span class="formValidation"><span id="component50" class="formNoError">Scegli una categoria</span></span></div>
4

8 回答 8

58

你要找的是这个:

select option:disabled {
    color: #000;
    font-weight: bold;
}

来,拉小提琴。

注意:根据评论部分的报告,此解决方案不适用于 OS X。

于 2014-09-12T11:13:03.330 回答
12

我使用:invalid来解决我的问题,描述如下:

因此,这些答案确实设置了禁用选项的样式,但仅在下拉列表中。如果您想将列表顶部的禁用选项显示为“请选择”,则不是。

希望这可以帮助其他与我遇到类似问题的人。

基本上,选择需要是必填字段才能工作:

<select required>

假设该选项位于列表顶部:

<option disabled selected value="">Please select</option>

你的 SCSS 看起来像这样:

select {

  // The select element is set to required
  // as long as the selected options value
  // is empty the element is not valid.
  &:invalid {
    color: gray;
  }

  // Styling for browsers which do support
  // styling select option elements directly
  [disabled] {
    color: gray;
  }

  option {
    color: black;
  }
}

所以它是 :invalid 允许我们为禁用的选定选项着色。

感谢 Markus Oberlehner 的帖子:

博文:https ://markus.oberlehner.net/blog/faking-a-placeholder-in-a-html-select-form-field/

代码笔: https ://codepen.io/maoberlehner/pen/WOWrqO

于 2019-05-16T10:06:30.127 回答
4

有一种方法可以仅使用 CSS 来做到这一点。但是您需要调整您的 HTML 以遵循一些规则:

  • 设置你selectrequired
  • 禁用的选项需要有空值字段:value=""
  • 您需要设置:valid:invalid状态的样式

这是标记:

<select required>
    <option value="" selected disabled>Disabled default</option>
    <option value="" disabled>Just disabled</option>
    <option value="" >Empty but valid</option>
    <option value="a-value-here">Fully valid</option>
</select>
select {
   width: 500px;
   padding: 10px;
}

select:invalid {
   background: red;
}

select:valid {
   background: green;
}

这是小提琴:https ://jsfiddle.net/james2doyle/hw1m2cd9/

现在,当一种选项disabled和选项时value="":invalid将应用样式。您可以看到空值仍然可以。

如果只select支持pattern,那么我们可以改用正则表达式进行验证。在发表此评论时,它不支持且仅支持输入“文本”类型。

此解决方案应适用于 IE >= 10

于 2020-05-04T20:21:29.890 回答
3

I do not think you can target an option tag using pure CSS; you can only modify a select tag.

However, there are workarounds. See this question.

于 2013-03-24T18:24:18.557 回答
1
<select>
    <option value="volvo" >Volvo</option>
    <option value="saab">Saab</option>
    <option value="vw" disabled>VW</option>
    <option value="audi" class="colr">Audi</option>
    <option value="aaa">Something</option>
    <option value="ccc">Other</option>
    <option value="vw" disabled>VW</option>
    <option value="vvv">Apple</option>
    <option value="nnn" class="colr">Mango</option>
    <option value="cmmmcc">Plum</option>
</select>

option:disabled {
   background: #ccc;
   width: 500px;
   padding: 5px;
   }

option.colr {
   background: red;
   width: 500px;
   padding: 5px;
   }

检查链接 http://jsfiddle.net/W5B5p/110/

于 2015-06-17T10:34:52.310 回答
1

我使用了一个简单的技巧将禁用的选项设置为灰色,希望有人觉得它有用。

<label>
    <div id="disabledMask"></div>
    <select id="mySelect">
        <option disabled selected>Please Select</option>
        <option value="foo">Bar</option>
    </select>
</label>

<style>
    label {
        position: relative;
    }

    #disabledMask {
        position: absolute;
        background-color: #fff;
        opacity: 0.5;
        pointer-events: none;
        width: 100%;
        height: 100%;
        display: none;
    }
</style>

<script>
    var toggleMask = function(){
        var option = this.options[this.selectedIndex];
        var disabledMask = document.getElementById('disabledMask');
        disabledMask.style.display = option.disabled? 'block' : 'none';
    };

    var mySelect = document.getElementById('mySelect');
    mySelect.addEventListener('change', toggleMask);
    toggleMask.bind(mySelect)();
</script>

这是一个jsfiddle:https ://jsfiddle.net/jhavbzcx/

免责声明:根据您选择的样式,您可能需要设置#disabledMask 的样式,以免与下拉箭头重叠。

于 2019-06-03T14:12:15.610 回答
-2
<select class="dropdown" name="contactMethod">
<option selected disabled>Contact method:</option>
<option class="dropdownplus"> E-mail: </option>
<option class="dropdownplus"> Website </option>
<option class="dropdownplus"> None</option>
</select>

<style>
.dropdown {
  background-color: rgba(195, 0, 97, 0.1);
  width: 100%;
  border: 1px solid #CC0061;
  border-style: inset;
  color: grey;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  padding: 10px;
  margin-top: 10px;
  margin-bottom: 10px;
  }

option.dropdownplus {
  color: black;
}
</style>

见 img https://ibb.co/d9453b

于 2018-01-26T10:05:45.207 回答
-3
var select = document.getElementsByTagName("select");

for(var i = 0;i < select.length; i++)
{
var el = select[i];
var optVal = el.options[el.selectedIndex].value
el.addEventListener('change', function () {
// Using an if statement to check the class
    if (optVal == "") {
        el.classList.remove('not_chosen');
    } else {
        el.classList.add('not_chosen');
    }
});
}
于 2016-11-22T18:41:10.787 回答