根据值筛选 <SELECT> 个选项

Filter <SELECT> options based on value

我有 2 个输入 selects

国家和汽车

这是结构:[https://jsfiddle.net/CornerStone20/r1eanhwv/6/][1]

JSFIDDLE: [1]: https://jsfiddle.net/CornerStone20/r1eanhwv/6/

当我在select国家时,如何只显示select国家的汽车?

我试过:

$(function() {
    $('#Country_Select').on('change', function() {
        var val = this.value;
        $('#Cars_Select option').hide().filter(function() {
            return this.value.indexOf( val + '_' ) === 0;
        })
        .show();
    })
    .change();
});

您可以使用 each 循环遍历选项并检查 car select- 框的值是否与 country select-box 相同,具体取决于基于此 show()hide() 选项。

演示代码 :

$(function() {
  $('#Country_Select').on('change', function() {
    var val = this.value;
    $('#Cars_Select option').each(function() {
      //checking value of opton in cars selct is same
      if ($(this).val() == val) {
        $(this).show(); //show it
      } else {
        $(this).hide(); //hide other
      }
    })
  })
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
// Country select
<select id="Country_Select" class="form-control">
  <option selected="true" disabled="false">Choose Country</option>
  <option value="0001">France</option>
  <option value="8ebd9ec1-b121-44e9-a530-42f227359913">Germany</option>
  <option value="4dda2683-83c6-48c8-af9b-0a96991b7c8b">New Zealand</option>
</select>


// Cars

<select id="Cars_Select" class="form-control">
  <option selected="true" disabled="false">Choose Cars</option>
  <option value="0001">Renauld</option>
  <option value="0001">Mini</option>
  <option value="0001">Paris</option>
  <option value="8ebd9ec1-b121-44e9-a530-42f227359913">BMW</option>
  <option value="8ebd9ec1-b121-44e9-a530-42f227359913">Audi</option>
  <option value="8ebd9ec1-b121-44e9-a530-42f227359913">Mercedes</option>
  <option value="8ebd9ec1-b121-44e9-a530-42f227359913">Benz</option>
  <option value="4dda2683-83c6-48c8-af9b-0a96991b7c8b">Kiwi Auto</option>
</select>

虽然问题已经得到解答,但我在这里写了一个更好的方法:

$('#Country_Select').on('change', function(e) {
  let cars = $('#Cars_Select').children();
  cars.hide();
  let country = $(this).val();
  cars.filter('[value=' + country + ']').add(cars.eq(0)).show();
});