为了账号安全,请及时绑定邮箱和手机立即绑定

根据值筛选 <SELECT> 选项

根据值筛选 <SELECT> 选项

侃侃尔雅 2022-12-22 11:40:19
我有 2 个输入选择国家和汽车这是结构:[https://jsfiddle.net/CornerStone20/r1eanhwv/6/][1]JSFIDDLE: [1]:https ://jsfiddle.net/CornerStone20/r1eanhwv/6/当我选择国家时,如何只显示所选国家的汽车?我试过了:$(function() {    $('#Country_Select').on('change', function() {        var val = this.value;        $('#Cars_Select option').hide().filter(function() {            return this.value.indexOf( val + '_' ) === 0;        })        .show();    })    .change();});
查看完整描述

2 回答

?
qq_花开花谢_0

TA贡献1835条经验 获得超7个赞

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


演示代码:


$(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>


查看完整回答
反对 回复 2022-12-22
?
SMILET

TA贡献1796条经验 获得超4个赞

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


$('#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();

});


查看完整回答
反对 回复 2022-12-22
  • 2 回答
  • 0 关注
  • 77 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信