0

我的问题是“如何根据第一个选择在第二个下拉列表中更改选项颜色(或禁用)?” 使用 javascript/jquery。

例如:如果在我的第一个下拉列表中选择“13 个楼梯”,则 14 和 15 个楼梯在第二个下拉列表中应该具有“红色” (或禁用)颜色。

类似“如果选项==13 楼梯* -> 14* / 15* == 禁用”或“如​​果选择值“a”-> 值“先生”= 红色。

也许这很容易,但我完全是 Javascript 的小菜一碟。:( 希望有人能帮助我。

<form id="test" name="test" method="post" action="">
    <label for="demo"></label>
    <select name="first-election" id="first-election">
      <option value="a">13 Stairs - 001</option>
      <option value="b">13 Stairs - 002</option>
      <option value="c">13 Stairs - 003</option>
      <option value="d">14 Stairs - 001</option>
      <option value="e">14 Stairs - 002</option>
      <option value="f">14 Stairs - 003</option>
      <option value="g">15 Stairs - 001</option>
      <option value="h">15 Stairs - 002</option>
      <option value="i">15 Stairs - 003</option>
    </select>
<br /><br />
    <select name="color" id="color">
      <option value="j">13 Stairs - green</option>
      <option value="k">13 Stairs - yellow</option>
      <option value="l">13 Stairs - black</option>
      <option value="m">14 Stairs - green</option>
      <option value="n">14 Stairs - yellow</option>
      <option value="o">14 Stairs - black</option>
      <option value="p">15 Stairs - green</option>
      <option value="q">15 Stairs - yellow</option>
      <option value="r">15 Stairs - black</option>
    </select>
</form>
4

3 回答 3

0

除非您编写自己的自定义选择对象(由 Divs 制成并且看起来像股票选择但不使用标准浏览器对象),否则您不能将某些项目设置为一种颜色,而将其他项目设置为另一种颜色。但是,您可以重新绘制整个选择器以包含您想要的任何字段,因此您的第二种方法(隐藏不再相关的元素)是完全可行的。

您需要使用 onSelect 回调并将其放在第一个下拉列表中,然后编写一个函数,根据用户在第一个中选择的项目更改第二个下拉列表的内容。

于 2013-01-21T01:04:38.623 回答
0

以下是disables的方法option

var $options = $('#color').find('option');

$('#first-election').change(function () {

    var num = parseInt( $('option:selected', this).text(), 10 );

    $options.prop('disabled', false).filter(function () {
        return $.text(this).indexOf(num) !== 0;
    }).prop('disabled', true);

}).change();

这是小提琴:http: //jsfiddle.net/Gp7fF/

于 2013-01-21T01:09:58.550 回答
0

我认为你可以做到。看这个例子:http: //jsfiddle.net/TxbVt/773

HTML:

<select>
    <option>1111111</option>
    <option>222222222</option>
    <option>33333333</option>
    <option>44444444</option>
</select>

JS:

var options = document.getElementsByTagName('option');
for(var i = 0; i < options.length; i += 1) {
    var option = options[i];
    var colors = ['blue','yellow','purple','brown'];
    $(option).css('background-color',colors[i]);
}

点击选择表格,选项有不同的颜色。

于 2013-01-21T01:24:53.033 回答